fx-form-builder-wrapper 2.0.65 → 2.0.67

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.
@@ -41,8 +41,15 @@ export class DatePickerComponent extends FxBaseComponent {
41
41
  if (!variables)
42
42
  return;
43
43
  this.datePickerMap = new Map();
44
+ // for (const [key, value] of Object.entries(variables) as [string, any][]) {
45
+ // if (key.includes('lib-date-picker')) {
46
+ // this.datePickerMap.set(key, value);
47
+ // }
48
+ // }
44
49
  for (const [key, value] of Object.entries(variables)) {
45
- if (key.includes('lib-date-picker')) {
50
+ if (value &&
51
+ typeof value === 'object' &&
52
+ 'date' in value) {
46
53
  this.datePickerMap.set(key, value);
47
54
  }
48
55
  }
@@ -122,4 +129,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
122
129
  type: ViewChild,
123
130
  args: ['fxComponent']
124
131
  }] } });
125
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/fx-builder-wrapper/src/lib/components/date-picker/date-picker.component.ts","../../../../../../projects/fx-builder-wrapper/src/lib/components/date-picker/date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { ChangeDetectorRef, Component, inject, OnInit, ViewChild } from '@angular/core';\r\nimport { ReactiveFormsModule, FormsModule, FormBuilder, FormGroup, Validators } from '@angular/forms';\r\nimport { FxBaseComponent, FxComponent, FxSetting, FxStringSetting, FxValidation, FxValidatorService } from '@instantsys-labs/fx';\r\nimport { CalendarModule } from 'primeng/calendar';\r\nimport { FxBuilderWrapperService } from '../../fx-builder-wrapper.service';\r\nimport { Subject, takeUntil } from 'rxjs';\r\n@Component({\r\n  selector: 'lib-date-picker',\r\n  standalone: true,\r\n imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent, CalendarModule],\r\n  templateUrl: './date-picker.component.html',\r\n  styleUrl: './date-picker.component.css'\r\n})\r\nexport class DatePickerComponent extends FxBaseComponent implements OnInit{\r\n   private fb = inject(FormBuilder);\r\n  //  minDate = new Date();\r\n  //  maxDate  = new Date();\r\nminDate!: string;\r\nmaxDate!: string;\r\n   today = new Date();\r\n   @ViewChild('fxComponent') fxComponent!: FxComponent;\r\n   private destroy$ = new Subject<Boolean>();\r\n    datePickerMap = new Map<string, any>();\r\n   \r\n\r\n\r\n    public datePickerForm: FormGroup = this.fb.group({\r\n       date: [new Date(),[Validators.required]],\r\n     })\r\n\r\n   constructor(private cdr: ChangeDetectorRef,private http: HttpClient,private fxBuilderWrapperService: FxBuilderWrapperService) {\r\n      super(cdr)\r\n      this.onInit.subscribe(() => {\r\n        this._register(this.datePickerForm);\r\n      });\r\n     \r\n    }\r\n\r\n\r\n  ngOnInit(): void {\r\n\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    this.datePickerMap = new Map<string, any>();\r\n\r\n    for (const [key, value] of Object.entries(variables) as [string, any][]) {\r\n      if (key.includes('lib-date-picker')) {\r\n        this.datePickerMap.set(key, value);\r\n      }\r\n    }\r\n  });\r\n\r\n\r\n    // const today = new Date();\r\n    // this.minDate = new Date(today);\r\n    // this.minDate.setDate(today.getDate() - 30);\r\n\r\n    // this.maxDate = new Date(today);\r\n    // this.maxDate.setDate(today.getDate() + 30);\r\n\r\n  // this.minDate = this.formatDate(new Date(this.today.setDate(new Date().getDate() - 30)));\r\n  // this.maxDate = this.formatDate(new Date(this.today.setDate(new Date().getDate() + 31)));\r\n\r\n  const today = new Date();\r\n\r\nconst min = new Date();\r\nmin.setDate(today.getDate() - 30);\r\n\r\nconst max = new Date();\r\nmax.setDate(today.getDate());\r\n\r\nthis.minDate = this.formatDate(min);\r\nthis.maxDate = this.formatDate(max);\r\n\r\n    // this.getRangeValues();\r\n\r\n\r\n  }\r\n\r\n  get dateControl() {\r\n    return this.datePickerForm.get('date');\r\n  }\r\n\r\n   ngAfterViewInit(): void {\r\n    const key = this.fxComponent?.fxData?.name;\r\n    if(key){\r\n        const datePatch = this.datePickerMap.get(key)\r\n        const finalDate = datePatch || this.formatDate(new Date())\r\n        if(datePatch){\r\n            this.minDate = datePatch\r\n        }\r\n        else{\r\n         this.minDate = this.formatDate(new Date(this.today.setDate(new Date().getDate() - 30)));\r\n        }\r\n        \r\n\r\n      this.datePickerForm.patchValue({date:finalDate});\r\n    }\r\n    this.getContextBaseId();\r\n  }\r\n\r\n  getRangeValues() {\r\n    this.http.get<any>(this.setting('apiURL')).subscribe(response => {\r\n      const today = new Date();\r\n  \r\n      const minOffset = response[this.setting('minDateKey')] || this.setting('minValidation');\r\n      const maxOffset = response[this.setting('maxDateKey')] || this.setting('maxValidation');\r\n  \r\n      // this.minDate = new Date(today);\r\n      // this.minDate.setDate(today.getDate() + minOffset);\r\n  \r\n      // this.maxDate = new Date(today);\r\n      // this.maxDate.setDate(today.getDate() + maxOffset);\r\n\r\n    this.minDate = this.formatDate(new Date(this.today.setDate(new Date().getDate() + minOffset)));\r\n  this.maxDate = this.formatDate(new Date(this.today.setDate(new Date().getDate() + maxOffset)));\r\n    });\r\n  }\r\n\r\n  private formatDate(date: Date): string {\r\n  return date.toISOString().split('T')[0]; \r\n}\r\n  \r\n\r\n\r\n    protected settings(): FxSetting[] {\r\n        return [\r\n          new FxStringSetting({ key: 'minValidation', $title: 'Min Validation', value: '' }),\r\n          new FxStringSetting({ key: 'maxValidation', $title: 'Max Validation', value: '' }),\r\n          new FxStringSetting({ key: 'apiURL', $title: 'API Url', value: '' }),\r\n          new FxStringSetting({ key: 'minDateKey', $title: 'Min Range API Key', value: '' }),\r\n          new FxStringSetting({ key: 'maxDateKey', $title: 'Max Range API Key', value: '' }),\r\n          new FxStringSetting({ key: 'placeHolder', $title: 'Placeholder', value: 'Select Date' }),\r\n          new FxStringSetting({ key: 'label', $title: 'Label', value: '' }),\r\n          new FxStringSetting({ key: 'datePickerErrorMessage', $title: 'Error Message', value: 'Please fill out the field' }),\r\n         \r\n        ];\r\n      }\r\n    \r\n      protected validations(): FxValidation[] {\r\n        return [FxValidatorService.required];\r\n      }\r\n}\r\n","<fx-component [fxData]=\"fxData\" #fxComponent>\r\n  <div class=\"custom-date-picker relative\">\r\n    <form [formGroup]=\"datePickerForm\">\r\n      <!-- <p-calendar  formControlName=\"date\" [showIcon]=\"true\" [minDate]=\"minDate\" [maxDate]=\"maxDate\"\r\n        [iconDisplay]=\"'input'\" [showOnFocus]=\"false\" dateFormat=\"dd/mm/yy\" [showButtonBar]=\"true\"\r\n        placeholder=\"{{ setting('placeHolder') }}\">\r\n        <ng-template pTemplate=\"inputicon\">\r\n          <span class=\"absolute right-0 pt-2 pr-2\">\r\n            <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"\r\n               class=\"cursor-pointer\">\r\n              <path\r\n                d=\"M19.5624 2.25991H18.1956V3.13582C18.1956 3.61948 17.7982 4.01173 17.3078 4.01173C16.8177 4.01173 16.4202 3.61948 16.4202 3.13582V2.25991H7.58001V3.13582C7.58001 3.61948 7.18253 4.01173 6.69244 4.01173C6.20209 4.01173 5.80486 3.61948 5.80486 3.13582V2.25991H4.43787C3.26107 2.2604 2.13252 2.72182 1.30042 3.54299C0.468323 4.36441 0.000507185 5.47813 0 6.63946V19.6204C0.000495266 20.7818 0.468304 21.8955 1.30042 22.7167C2.13252 23.5381 3.26107 23.9995 4.43787 24H19.5621C20.7389 23.9995 21.8675 23.5381 22.6996 22.7167C23.5317 21.8955 23.9995 20.7818 24 19.6204V6.63946C23.9995 5.47813 23.5317 4.36441 22.6996 3.54299C21.8675 2.72183 20.7389 2.26041 19.5621 2.25991H19.5624ZM19.5624 22.2482H4.43818C3.73262 22.246 3.05655 21.9686 2.55779 21.4761C2.05878 20.9839 1.77768 20.3167 1.77546 19.6204V9.05698H22.2252V19.6204C22.2229 20.3167 21.9419 20.9839 21.4428 21.4761C20.9441 21.9686 20.268 22.246 19.5624 22.2482ZM7.58001 2.25991H5.80486L5.80505 0.87591C5.80505 0.392251 6.20227 0 6.69262 0C7.18272 0 7.58019 0.392251 7.58019 0.87591L7.58001 2.25991ZM18.1956 2.25991H16.4202L16.4202 0.87591C16.4202 0.392251 16.8177 0 17.3078 0C17.7981 0 18.1953 0.392251 18.1953 0.87591L18.1956 2.25991Z\"\r\n                fill=\"#F3A041\" />\r\n              <rect x=\"5.33203\" y=\"11.5547\" width=\"2.96296\" height=\"2.96296\" rx=\"0.444444\" fill=\"#F3A041\" />\r\n              <rect x=\"5.33203\" y=\"16.5898\" width=\"2.96296\" height=\"2.96296\" rx=\"0.444444\" fill=\"#F3A041\" />\r\n              <rect x=\"10.3711\" y=\"11.5547\" width=\"2.96296\" height=\"2.96296\" rx=\"0.444444\" fill=\"#F3A041\" />\r\n              <rect x=\"10.3711\" y=\"16.5898\" width=\"2.96296\" height=\"2.96296\" rx=\"0.444444\" fill=\"#F3A041\" />\r\n              <rect x=\"15.4062\" y=\"11.5547\" width=\"2.96296\" height=\"2.96296\" rx=\"0.444444\" fill=\"#F3A041\" />\r\n              <rect x=\"15.4062\" y=\"16.5898\" width=\"2.96296\" height=\"2.96296\" rx=\"0.444444\" fill=\"#F3A041\" />\r\n            </svg>\r\n          </span>\r\n        </ng-template>\r\n      </p-calendar> -->\r\n          <!-- <p-calendar  formControlName=\"date\"\r\n          dateFormat=\"dd/mm/yy\"\r\n        placeholder=\"{{ setting('placeHolder') }}\"> -->\r\n        <label for=\"date\">{{ setting('label') }}</label>\r\n        <div class=\"relative\">\r\n        <input type=\"date\" id=\"date\" name=\"date\" formControlName=\"date\"  [min]=\"minDate\" [max]=\"maxDate\">\r\n        </div>\r\n        <!-- <label for=\"date\" class=\"placeholder\">Select Date</label> -->\r\n        <!-- <ng-template pTemplate=\"inputicon\">\r\n          <span class=\"absolute right-0 pt-2 pr-2\">\r\n            <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"\r\n               class=\"cursor-pointer\">\r\n              <path\r\n                d=\"M19.5624 2.25991H18.1956V3.13582C18.1956 3.61948 17.7982 4.01173 17.3078 4.01173C16.8177 4.01173 16.4202 3.61948 16.4202 3.13582V2.25991H7.58001V3.13582C7.58001 3.61948 7.18253 4.01173 6.69244 4.01173C6.20209 4.01173 5.80486 3.61948 5.80486 3.13582V2.25991H4.43787C3.26107 2.2604 2.13252 2.72182 1.30042 3.54299C0.468323 4.36441 0.000507185 5.47813 0 6.63946V19.6204C0.000495266 20.7818 0.468304 21.8955 1.30042 22.7167C2.13252 23.5381 3.26107 23.9995 4.43787 24H19.5621C20.7389 23.9995 21.8675 23.5381 22.6996 22.7167C23.5317 21.8955 23.9995 20.7818 24 19.6204V6.63946C23.9995 5.47813 23.5317 4.36441 22.6996 3.54299C21.8675 2.72183 20.7389 2.26041 19.5621 2.25991H19.5624ZM19.5624 22.2482H4.43818C3.73262 22.246 3.05655 21.9686 2.55779 21.4761C2.05878 20.9839 1.77768 20.3167 1.77546 19.6204V9.05698H22.2252V19.6204C22.2229 20.3167 21.9419 20.9839 21.4428 21.4761C20.9441 21.9686 20.268 22.246 19.5624 22.2482ZM7.58001 2.25991H5.80486L5.80505 0.87591C5.80505 0.392251 6.20227 0 6.69262 0C7.18272 0 7.58019 0.392251 7.58019 0.87591L7.58001 2.25991ZM18.1956 2.25991H16.4202L16.4202 0.87591C16.4202 0.392251 16.8177 0 17.3078 0C17.7981 0 18.1953 0.392251 18.1953 0.87591L18.1956 2.25991Z\"\r\n                fill=\"#F3A041\" />\r\n              <rect x=\"5.33203\" y=\"11.5547\" width=\"2.96296\" height=\"2.96296\" rx=\"0.444444\" fill=\"#F3A041\" />\r\n              <rect x=\"5.33203\" y=\"16.5898\" width=\"2.96296\" height=\"2.96296\" rx=\"0.444444\" fill=\"#F3A041\" />\r\n              <rect x=\"10.3711\" y=\"11.5547\" width=\"2.96296\" height=\"2.96296\" rx=\"0.444444\" fill=\"#F3A041\" />\r\n              <rect x=\"10.3711\" y=\"16.5898\" width=\"2.96296\" height=\"2.96296\" rx=\"0.444444\" fill=\"#F3A041\" />\r\n              <rect x=\"15.4062\" y=\"11.5547\" width=\"2.96296\" height=\"2.96296\" rx=\"0.444444\" fill=\"#F3A041\" />\r\n              <rect x=\"15.4062\" y=\"16.5898\" width=\"2.96296\" height=\"2.96296\" rx=\"0.444444\" fill=\"#F3A041\" />\r\n            </svg>\r\n          </span>\r\n        </ng-template> -->\r\n      <!-- </p-calendar> -->\r\n    <div>\r\n      <small *ngIf=\"datePickerForm.get('date')?.touched && datePickerForm.get('date')?.errors?.['required']\"\r\n        class=\"text-red-500\">\r\n      {{ setting('datePickerErrorMessage') }}\r\n      </small>\r\n    </div>\r\n    </form>\r\n  </div>\r\n\r\n</fx-component>"]}
132
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/fx-builder-wrapper/src/lib/components/date-picker/date-picker.component.ts","../../../../../../projects/fx-builder-wrapper/src/lib/components/date-picker/date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { ChangeDetectorRef, Component, inject, OnInit, ViewChild } from '@angular/core';\r\nimport { ReactiveFormsModule, FormsModule, FormBuilder, FormGroup, Validators } from '@angular/forms';\r\nimport { FxBaseComponent, FxComponent, FxSetting, FxStringSetting, FxValidation, FxValidatorService } from '@instantsys-labs/fx';\r\nimport { CalendarModule } from 'primeng/calendar';\r\nimport { FxBuilderWrapperService } from '../../fx-builder-wrapper.service';\r\nimport { Subject, takeUntil } from 'rxjs';\r\n@Component({\r\n  selector: 'lib-date-picker',\r\n  standalone: true,\r\n imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent, CalendarModule],\r\n  templateUrl: './date-picker.component.html',\r\n  styleUrl: './date-picker.component.css'\r\n})\r\nexport class DatePickerComponent extends FxBaseComponent implements OnInit{\r\n   private fb = inject(FormBuilder);\r\n  //  minDate = new Date();\r\n  //  maxDate  = new Date();\r\nminDate!: string;\r\nmaxDate!: string;\r\n   today = new Date();\r\n   @ViewChild('fxComponent') fxComponent!: FxComponent;\r\n   private destroy$ = new Subject<Boolean>();\r\n    datePickerMap = new Map<string, any>();\r\n   \r\n\r\n\r\n    public datePickerForm: FormGroup = this.fb.group({\r\n       date: [new Date(),[Validators.required]],\r\n     })\r\n\r\n   constructor(private cdr: ChangeDetectorRef,private http: HttpClient,private fxBuilderWrapperService: FxBuilderWrapperService) {\r\n      super(cdr)\r\n      this.onInit.subscribe(() => {\r\n        this._register(this.datePickerForm);\r\n      });\r\n     \r\n    }\r\n\r\n\r\n  ngOnInit(): void {\r\n\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    this.datePickerMap = new Map<string, any>();\r\n\r\n    // for (const [key, value] of Object.entries(variables) as [string, any][]) {\r\n    //   if (key.includes('lib-date-picker')) {\r\n    //     this.datePickerMap.set(key, 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    'date' in value\r\n  ) {\r\n    this.datePickerMap.set(key, value);\r\n  }\r\n}\r\n  });\r\n\r\n\r\n    // const today = new Date();\r\n    // this.minDate = new Date(today);\r\n    // this.minDate.setDate(today.getDate() - 30);\r\n\r\n    // this.maxDate = new Date(today);\r\n    // this.maxDate.setDate(today.getDate() + 30);\r\n\r\n  // this.minDate = this.formatDate(new Date(this.today.setDate(new Date().getDate() - 30)));\r\n  // this.maxDate = this.formatDate(new Date(this.today.setDate(new Date().getDate() + 31)));\r\n\r\n  const today = new Date();\r\n\r\nconst min = new Date();\r\nmin.setDate(today.getDate() - 30);\r\n\r\nconst max = new Date();\r\nmax.setDate(today.getDate());\r\n\r\nthis.minDate = this.formatDate(min);\r\nthis.maxDate = this.formatDate(max);\r\n\r\n    // this.getRangeValues();\r\n\r\n\r\n  }\r\n\r\n  get dateControl() {\r\n    return this.datePickerForm.get('date');\r\n  }\r\n\r\n   ngAfterViewInit(): void {\r\n    const key = this.fxComponent?.fxData?.name;\r\n    if(key){\r\n        const datePatch = this.datePickerMap.get(key)\r\n        const finalDate = datePatch || this.formatDate(new Date())\r\n        if(datePatch){\r\n            this.minDate = datePatch\r\n        }\r\n        else{\r\n         this.minDate = this.formatDate(new Date(this.today.setDate(new Date().getDate() - 30)));\r\n        }\r\n        \r\n\r\n      this.datePickerForm.patchValue({date:finalDate});\r\n    }\r\n    this.getContextBaseId();\r\n  }\r\n\r\n  getRangeValues() {\r\n    this.http.get<any>(this.setting('apiURL')).subscribe(response => {\r\n      const today = new Date();\r\n  \r\n      const minOffset = response[this.setting('minDateKey')] || this.setting('minValidation');\r\n      const maxOffset = response[this.setting('maxDateKey')] || this.setting('maxValidation');\r\n  \r\n      // this.minDate = new Date(today);\r\n      // this.minDate.setDate(today.getDate() + minOffset);\r\n  \r\n      // this.maxDate = new Date(today);\r\n      // this.maxDate.setDate(today.getDate() + maxOffset);\r\n\r\n    this.minDate = this.formatDate(new Date(this.today.setDate(new Date().getDate() + minOffset)));\r\n  this.maxDate = this.formatDate(new Date(this.today.setDate(new Date().getDate() + maxOffset)));\r\n    });\r\n  }\r\n\r\n  private formatDate(date: Date): string {\r\n  return date.toISOString().split('T')[0]; \r\n}\r\n  \r\n\r\n\r\n    protected settings(): FxSetting[] {\r\n        return [\r\n          new FxStringSetting({ key: 'minValidation', $title: 'Min Validation', value: '' }),\r\n          new FxStringSetting({ key: 'maxValidation', $title: 'Max Validation', value: '' }),\r\n          new FxStringSetting({ key: 'apiURL', $title: 'API Url', value: '' }),\r\n          new FxStringSetting({ key: 'minDateKey', $title: 'Min Range API Key', value: '' }),\r\n          new FxStringSetting({ key: 'maxDateKey', $title: 'Max Range API Key', value: '' }),\r\n          new FxStringSetting({ key: 'placeHolder', $title: 'Placeholder', value: 'Select Date' }),\r\n          new FxStringSetting({ key: 'label', $title: 'Label', value: '' }),\r\n          new FxStringSetting({ key: 'datePickerErrorMessage', $title: 'Error Message', value: 'Please fill out the field' }),\r\n         \r\n        ];\r\n      }\r\n    \r\n      protected validations(): FxValidation[] {\r\n        return [FxValidatorService.required];\r\n      }\r\n}\r\n","<fx-component [fxData]=\"fxData\" #fxComponent>\r\n  <div class=\"custom-date-picker relative\">\r\n    <form [formGroup]=\"datePickerForm\">\r\n      <!-- <p-calendar  formControlName=\"date\" [showIcon]=\"true\" [minDate]=\"minDate\" [maxDate]=\"maxDate\"\r\n        [iconDisplay]=\"'input'\" [showOnFocus]=\"false\" dateFormat=\"dd/mm/yy\" [showButtonBar]=\"true\"\r\n        placeholder=\"{{ setting('placeHolder') }}\">\r\n        <ng-template pTemplate=\"inputicon\">\r\n          <span class=\"absolute right-0 pt-2 pr-2\">\r\n            <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"\r\n               class=\"cursor-pointer\">\r\n              <path\r\n                d=\"M19.5624 2.25991H18.1956V3.13582C18.1956 3.61948 17.7982 4.01173 17.3078 4.01173C16.8177 4.01173 16.4202 3.61948 16.4202 3.13582V2.25991H7.58001V3.13582C7.58001 3.61948 7.18253 4.01173 6.69244 4.01173C6.20209 4.01173 5.80486 3.61948 5.80486 3.13582V2.25991H4.43787C3.26107 2.2604 2.13252 2.72182 1.30042 3.54299C0.468323 4.36441 0.000507185 5.47813 0 6.63946V19.6204C0.000495266 20.7818 0.468304 21.8955 1.30042 22.7167C2.13252 23.5381 3.26107 23.9995 4.43787 24H19.5621C20.7389 23.9995 21.8675 23.5381 22.6996 22.7167C23.5317 21.8955 23.9995 20.7818 24 19.6204V6.63946C23.9995 5.47813 23.5317 4.36441 22.6996 3.54299C21.8675 2.72183 20.7389 2.26041 19.5621 2.25991H19.5624ZM19.5624 22.2482H4.43818C3.73262 22.246 3.05655 21.9686 2.55779 21.4761C2.05878 20.9839 1.77768 20.3167 1.77546 19.6204V9.05698H22.2252V19.6204C22.2229 20.3167 21.9419 20.9839 21.4428 21.4761C20.9441 21.9686 20.268 22.246 19.5624 22.2482ZM7.58001 2.25991H5.80486L5.80505 0.87591C5.80505 0.392251 6.20227 0 6.69262 0C7.18272 0 7.58019 0.392251 7.58019 0.87591L7.58001 2.25991ZM18.1956 2.25991H16.4202L16.4202 0.87591C16.4202 0.392251 16.8177 0 17.3078 0C17.7981 0 18.1953 0.392251 18.1953 0.87591L18.1956 2.25991Z\"\r\n                fill=\"#F3A041\" />\r\n              <rect x=\"5.33203\" y=\"11.5547\" width=\"2.96296\" height=\"2.96296\" rx=\"0.444444\" fill=\"#F3A041\" />\r\n              <rect x=\"5.33203\" y=\"16.5898\" width=\"2.96296\" height=\"2.96296\" rx=\"0.444444\" fill=\"#F3A041\" />\r\n              <rect x=\"10.3711\" y=\"11.5547\" width=\"2.96296\" height=\"2.96296\" rx=\"0.444444\" fill=\"#F3A041\" />\r\n              <rect x=\"10.3711\" y=\"16.5898\" width=\"2.96296\" height=\"2.96296\" rx=\"0.444444\" fill=\"#F3A041\" />\r\n              <rect x=\"15.4062\" y=\"11.5547\" width=\"2.96296\" height=\"2.96296\" rx=\"0.444444\" fill=\"#F3A041\" />\r\n              <rect x=\"15.4062\" y=\"16.5898\" width=\"2.96296\" height=\"2.96296\" rx=\"0.444444\" fill=\"#F3A041\" />\r\n            </svg>\r\n          </span>\r\n        </ng-template>\r\n      </p-calendar> -->\r\n          <!-- <p-calendar  formControlName=\"date\"\r\n          dateFormat=\"dd/mm/yy\"\r\n        placeholder=\"{{ setting('placeHolder') }}\"> -->\r\n        <label for=\"date\">{{ setting('label') }}</label>\r\n        <div class=\"relative\">\r\n        <input type=\"date\" id=\"date\" name=\"date\" formControlName=\"date\"  [min]=\"minDate\" [max]=\"maxDate\">\r\n        </div>\r\n        <!-- <label for=\"date\" class=\"placeholder\">Select Date</label> -->\r\n        <!-- <ng-template pTemplate=\"inputicon\">\r\n          <span class=\"absolute right-0 pt-2 pr-2\">\r\n            <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"\r\n               class=\"cursor-pointer\">\r\n              <path\r\n                d=\"M19.5624 2.25991H18.1956V3.13582C18.1956 3.61948 17.7982 4.01173 17.3078 4.01173C16.8177 4.01173 16.4202 3.61948 16.4202 3.13582V2.25991H7.58001V3.13582C7.58001 3.61948 7.18253 4.01173 6.69244 4.01173C6.20209 4.01173 5.80486 3.61948 5.80486 3.13582V2.25991H4.43787C3.26107 2.2604 2.13252 2.72182 1.30042 3.54299C0.468323 4.36441 0.000507185 5.47813 0 6.63946V19.6204C0.000495266 20.7818 0.468304 21.8955 1.30042 22.7167C2.13252 23.5381 3.26107 23.9995 4.43787 24H19.5621C20.7389 23.9995 21.8675 23.5381 22.6996 22.7167C23.5317 21.8955 23.9995 20.7818 24 19.6204V6.63946C23.9995 5.47813 23.5317 4.36441 22.6996 3.54299C21.8675 2.72183 20.7389 2.26041 19.5621 2.25991H19.5624ZM19.5624 22.2482H4.43818C3.73262 22.246 3.05655 21.9686 2.55779 21.4761C2.05878 20.9839 1.77768 20.3167 1.77546 19.6204V9.05698H22.2252V19.6204C22.2229 20.3167 21.9419 20.9839 21.4428 21.4761C20.9441 21.9686 20.268 22.246 19.5624 22.2482ZM7.58001 2.25991H5.80486L5.80505 0.87591C5.80505 0.392251 6.20227 0 6.69262 0C7.18272 0 7.58019 0.392251 7.58019 0.87591L7.58001 2.25991ZM18.1956 2.25991H16.4202L16.4202 0.87591C16.4202 0.392251 16.8177 0 17.3078 0C17.7981 0 18.1953 0.392251 18.1953 0.87591L18.1956 2.25991Z\"\r\n                fill=\"#F3A041\" />\r\n              <rect x=\"5.33203\" y=\"11.5547\" width=\"2.96296\" height=\"2.96296\" rx=\"0.444444\" fill=\"#F3A041\" />\r\n              <rect x=\"5.33203\" y=\"16.5898\" width=\"2.96296\" height=\"2.96296\" rx=\"0.444444\" fill=\"#F3A041\" />\r\n              <rect x=\"10.3711\" y=\"11.5547\" width=\"2.96296\" height=\"2.96296\" rx=\"0.444444\" fill=\"#F3A041\" />\r\n              <rect x=\"10.3711\" y=\"16.5898\" width=\"2.96296\" height=\"2.96296\" rx=\"0.444444\" fill=\"#F3A041\" />\r\n              <rect x=\"15.4062\" y=\"11.5547\" width=\"2.96296\" height=\"2.96296\" rx=\"0.444444\" fill=\"#F3A041\" />\r\n              <rect x=\"15.4062\" y=\"16.5898\" width=\"2.96296\" height=\"2.96296\" rx=\"0.444444\" fill=\"#F3A041\" />\r\n            </svg>\r\n          </span>\r\n        </ng-template> -->\r\n      <!-- </p-calendar> -->\r\n    <div>\r\n      <small *ngIf=\"datePickerForm.get('date')?.touched && datePickerForm.get('date')?.errors?.['required']\"\r\n        class=\"text-red-500\">\r\n      {{ setting('datePickerErrorMessage') }}\r\n      </small>\r\n    </div>\r\n    </form>\r\n  </div>\r\n\r\n</fx-component>"]}
@@ -24,6 +24,7 @@ export class RadioGroupComponent extends FxBaseComponent {
24
24
  confirmationForm = this.fb.group({
25
25
  confirmation: ['', Validators.required],
26
26
  remarks: [''],
27
+ valueToShowTextArea: ['']
27
28
  });
28
29
  options = [
29
30
  { option: 'Yes', value: 'YES' },
@@ -48,6 +49,8 @@ export class RadioGroupComponent extends FxBaseComponent {
48
49
  const key = this.fxComponent?.fxData?.name;
49
50
  if (key && this.radoioMap.has(key)) {
50
51
  this.confirmationForm.patchValue(this.radoioMap.get(key));
52
+ const data = this.radoioMap.get(key);
53
+ this.onSelectionChange(data.confirmation);
51
54
  }
52
55
  }, 200);
53
56
  }
@@ -74,12 +77,15 @@ export class RadioGroupComponent extends FxBaseComponent {
74
77
  // this.setting('items').length > 0 ? this.options = this.setting('items') : null;
75
78
  this.confirmationForm.get('confirmation')?.valueChanges.subscribe(value => {
76
79
  const otherControl = this.confirmationForm.get('remarks');
80
+ const valueToShowTextArea = this.confirmationForm.get('valueToShowTextArea');
77
81
  if (value) {
78
82
  otherControl?.setValidators([Validators.required]);
83
+ valueToShowTextArea?.setValue(this.setting('value-show-text'));
79
84
  }
80
85
  else {
81
86
  otherControl?.setValidators([Validators.required]);
82
87
  otherControl?.reset();
88
+ valueToShowTextArea?.reset();
83
89
  }
84
90
  });
85
91
  }
@@ -97,7 +103,7 @@ export class RadioGroupComponent extends FxBaseComponent {
97
103
  new FxStringSetting({ key: 'additional-field-label', $title: 'Additional field label', value: '' }),
98
104
  new FxStringSetting({ key: 'additional-field-error-msg', $title: 'Additional field error message', value: 'Please fill out the field' }),
99
105
  new FxStringSetting({ key: 'error-msg', $title: 'Error message', value: 'Please select' }),
100
- new FxStringSetting({ key: 'remark-placeholder', $title: 'Error message', value: 'Please select' }),
106
+ new FxStringSetting({ key: 'remark-placeholder', $title: 'Additional field placeholder', value: 'enter here' }),
101
107
  // new FxStringSetting({ key: 'other-placeholder', $title: 'Other Placeholder', value: '' }),
102
108
  // 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'}]),
103
109
  // // new FxSelectSetting({key: 'service', $title: 'Service', value: 'local'}, [{option: 'Local', value: 'local'}, {option: 'QA', value: 'qa'},{option: 'UAT', value: 'uat'},{option: 'Production', value: 'prod'}]),
@@ -112,15 +118,15 @@ export class RadioGroupComponent extends FxBaseComponent {
112
118
  this.showTextArea = selection === this.setting('value-show-text');
113
119
  }
114
120
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RadioGroupComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.HttpClient }, { token: i2.FxBuilderWrapperService }, { token: i3.ApiServiceRegistry }], target: i0.ɵɵFactoryTarget.Component });
115
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: RadioGroupComponent, isStandalone: true, selector: "radio-group-custom", inputs: { showOnSelection: "showOnSelection" }, viewQueries: [{ propertyName: "fxComponent", first: true, predicate: ["fxComponent"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<fx-component [fxData]=\"fxData\" #fxComponent>\r\n <form [formGroup]=\"confirmationForm\" class=\"flex flex-col gap-4\">\r\n\r\n <!-- Title -->\r\n <label class=\"font-semibold text-gray-800\">\r\n {{ setting('select-label') }}\r\n </label>\r\n\r\n <!-- ROW -->\r\n <div class=\"flex items-start gap-16\">\r\n\r\n <!-- RADIO GROUP -->\r\n <div class=\"flex flex-col\">\r\n <div class=\"flex items-center gap-8\">\r\n\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\"\r\n />\r\n <span>{{ opt.option }}</span>\r\n </label>\r\n\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 </div>\r\n\r\n <!-- REMARKS -->\r\n <div *ngIf=\"showTextArea\" class=\"flex flex-col w-80\">\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=\"Enter details...\"\r\n class=\"border border-gray-300 rounded-lg p-3 w-full \r\n resize-none shadow-sm\r\n focus:outline-none focus:ring-2 focus:ring-blue-500\"\r\n ></textarea>\r\n\r\n <!-- 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 </div>\r\n\r\n </form>\r\n</fx-component>\r\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i5.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.RadioControlValueAccessor, selector: "input[type=radio][formControlName],input[type=radio][formControl],input[type=radio][ngModel]", inputs: ["name", "formControlName", "value"] }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i5.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i5.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: FormsModule }, { kind: "component", type: FxComponent, selector: "fx-component", inputs: ["fxData"] }, { kind: "ngmodule", type: CalendarModule }, { kind: "ngmodule", type: RadioButtonModule }] });
121
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: RadioGroupComponent, isStandalone: true, selector: "radio-group-custom", inputs: { showOnSelection: "showOnSelection" }, viewQueries: [{ propertyName: "fxComponent", first: true, predicate: ["fxComponent"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<fx-component [fxData]=\"fxData\" #fxComponent>\r\n <form [formGroup]=\"confirmationForm\" class=\"flex flex-col gap-4\">\r\n\r\n <!-- Title -->\r\n <label class=\"font-semibold text-gray-800\">\r\n {{ setting('select-label') }}\r\n </label>\r\n\r\n <!-- ROW -->\r\n <div class=\"flex items-start gap-16\">\r\n\r\n <!-- RADIO GROUP -->\r\n <div class=\"flex flex-col\">\r\n <div class=\"flex items-center custom-gap\">\r\n\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\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 </div>\r\n\r\n <!-- REMARKS -->\r\n <div *ngIf=\"showTextArea\" class=\"flex flex-col w-80 ml-4\">\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('additional-field-label') }}\"\r\n class=\"border border-gray-300 rounded-lg p-3 w-full \r\n resize-none shadow-sm\r\n focus:outline-none focus:ring-2 focus:ring-blue-500\"\r\n ></textarea>\r\n\r\n <!-- 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 </div>\r\n\r\n </form>\r\n</fx-component>\r\n", styles: [".custom-gap{gap:1rem}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i5.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.RadioControlValueAccessor, selector: "input[type=radio][formControlName],input[type=radio][formControl],input[type=radio][ngModel]", inputs: ["name", "formControlName", "value"] }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i5.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i5.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: FormsModule }, { kind: "component", type: FxComponent, selector: "fx-component", inputs: ["fxData"] }, { kind: "ngmodule", type: CalendarModule }, { kind: "ngmodule", type: RadioButtonModule }] });
116
122
  }
117
123
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RadioGroupComponent, decorators: [{
118
124
  type: Component,
119
- args: [{ selector: 'radio-group-custom', standalone: true, imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent, CalendarModule, RadioButtonModule], template: "<fx-component [fxData]=\"fxData\" #fxComponent>\r\n <form [formGroup]=\"confirmationForm\" class=\"flex flex-col gap-4\">\r\n\r\n <!-- Title -->\r\n <label class=\"font-semibold text-gray-800\">\r\n {{ setting('select-label') }}\r\n </label>\r\n\r\n <!-- ROW -->\r\n <div class=\"flex items-start gap-16\">\r\n\r\n <!-- RADIO GROUP -->\r\n <div class=\"flex flex-col\">\r\n <div class=\"flex items-center gap-8\">\r\n\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\"\r\n />\r\n <span>{{ opt.option }}</span>\r\n </label>\r\n\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 </div>\r\n\r\n <!-- REMARKS -->\r\n <div *ngIf=\"showTextArea\" class=\"flex flex-col w-80\">\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=\"Enter details...\"\r\n class=\"border border-gray-300 rounded-lg p-3 w-full \r\n resize-none shadow-sm\r\n focus:outline-none focus:ring-2 focus:ring-blue-500\"\r\n ></textarea>\r\n\r\n <!-- 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 </div>\r\n\r\n </form>\r\n</fx-component>\r\n" }]
125
+ args: [{ selector: 'radio-group-custom', standalone: true, imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent, CalendarModule, RadioButtonModule], template: "<fx-component [fxData]=\"fxData\" #fxComponent>\r\n <form [formGroup]=\"confirmationForm\" class=\"flex flex-col gap-4\">\r\n\r\n <!-- Title -->\r\n <label class=\"font-semibold text-gray-800\">\r\n {{ setting('select-label') }}\r\n </label>\r\n\r\n <!-- ROW -->\r\n <div class=\"flex items-start gap-16\">\r\n\r\n <!-- RADIO GROUP -->\r\n <div class=\"flex flex-col\">\r\n <div class=\"flex items-center custom-gap\">\r\n\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\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 </div>\r\n\r\n <!-- REMARKS -->\r\n <div *ngIf=\"showTextArea\" class=\"flex flex-col w-80 ml-4\">\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('additional-field-label') }}\"\r\n class=\"border border-gray-300 rounded-lg p-3 w-full \r\n resize-none shadow-sm\r\n focus:outline-none focus:ring-2 focus:ring-blue-500\"\r\n ></textarea>\r\n\r\n <!-- 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 </div>\r\n\r\n </form>\r\n</fx-component>\r\n", styles: [".custom-gap{gap:1rem}\n"] }]
120
126
  }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.HttpClient }, { type: i2.FxBuilderWrapperService }, { type: i3.ApiServiceRegistry }], propDecorators: { showOnSelection: [{
121
127
  type: Input
122
128
  }], fxComponent: [{
123
129
  type: ViewChild,
124
130
  args: ['fxComponent']
125
131
  }] } });
126
- //# 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: ['',Validators.required],\r\n      remarks: [''],\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       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  }\r\n}, 200);\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         if (value) {\r\n           otherControl?.setValidators([Validators.required]);\r\n         } else {\r\n           otherControl?.setValidators([Validators.required]);\r\n           otherControl?.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: 'customClass', $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: 'Error message', value: 'Please select' }),\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    this.showTextArea = selection === this.setting('value-show-text');\r\n  }\r\n}\r\n","<fx-component [fxData]=\"fxData\" #fxComponent>\r\n  <form [formGroup]=\"confirmationForm\" class=\"flex flex-col gap-4\">\r\n\r\n    <!-- Title -->\r\n    <label class=\"font-semibold text-gray-800\">\r\n      {{ setting('select-label') }}\r\n    </label>\r\n\r\n    <!-- ROW -->\r\n    <div class=\"flex items-start gap-16\">\r\n\r\n      <!-- RADIO GROUP -->\r\n      <div class=\"flex flex-col\">\r\n        <div class=\"flex items-center gap-8\">\r\n\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\"\r\n            />\r\n            <span>{{ opt.option }}</span>\r\n          </label>\r\n\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      </div>\r\n\r\n      <!-- REMARKS -->\r\n      <div *ngIf=\"showTextArea\" class=\"flex flex-col w-80\">\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=\"Enter details...\"\r\n          class=\"border border-gray-300 rounded-lg p-3 w-full \r\n                 resize-none shadow-sm\r\n                 focus:outline-none focus:ring-2 focus:ring-blue-500\"\r\n        ></textarea>\r\n\r\n        <!-- 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    </div>\r\n\r\n  </form>\r\n</fx-component>\r\n"]}
132
+ //# 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: ['',Validators.required],\r\n      remarks: [''],\r\n      valueToShowTextArea: ['']\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       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.confirmation);\r\n  }\r\n}, 200);\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?.setValidators([Validators.required]);\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: 'customClass', $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 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    this.showTextArea = selection === this.setting('value-show-text');\r\n  }\r\n}\r\n","<fx-component [fxData]=\"fxData\" #fxComponent>\r\n  <form [formGroup]=\"confirmationForm\" class=\"flex flex-col gap-4\">\r\n\r\n    <!-- Title -->\r\n    <label class=\"font-semibold text-gray-800\">\r\n      {{ setting('select-label') }}\r\n    </label>\r\n\r\n    <!-- ROW -->\r\n    <div class=\"flex items-start gap-16\">\r\n\r\n      <!-- RADIO GROUP -->\r\n      <div class=\"flex flex-col\">\r\n        <div class=\"flex items-center custom-gap\">\r\n\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\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      </div>\r\n\r\n      <!-- REMARKS -->\r\n      <div *ngIf=\"showTextArea\" class=\"flex flex-col w-80 ml-4\">\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('additional-field-label') }}\"\r\n          class=\"border border-gray-300 rounded-lg p-3 w-full \r\n                 resize-none shadow-sm\r\n                 focus:outline-none focus:ring-2 focus:ring-blue-500\"\r\n        ></textarea>\r\n\r\n        <!-- 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    </div>\r\n\r\n  </form>\r\n</fx-component>\r\n"]}