fx-form-builder-wrapper 2.0.79 → 2.0.80

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.
@@ -52,7 +52,7 @@ export class DropdownWithOtherComponent extends FxBaseComponent {
52
52
  }, 200);
53
53
  setTimeout(() => {
54
54
  const mainControl = this.dropDownForm.get('selectedOption');
55
- if (this.setting('isRequired')) {
55
+ if (this.setting('isRequired') === 'true') {
56
56
  mainControl?.setValidators([Validators.required]);
57
57
  mainControl?.updateValueAndValidity();
58
58
  }
@@ -142,4 +142,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
142
142
  type: ViewChild,
143
143
  args: ['fxComponent']
144
144
  }] } });
145
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-with-other.component.js","sourceRoot":"","sources":["../../../../../../projects/fx-builder-wrapper/src/lib/components/dropdown-with-other/dropdown-with-other.component.ts","../../../../../../projects/fx-builder-wrapper/src/lib/components/dropdown-with-other/dropdown-with-other.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { AfterViewInit, ChangeDetectorRef, Component, inject, OnInit, ViewChild } from '@angular/core';\r\nimport { FormBuilder, FormGroup, FormsModule, ReactiveFormsModule, Validators } from '@angular/forms';\r\nimport { FxBaseComponent, FxComponent, FxOptionSetting, FxSelectSetting, FxSetting, FxStringSetting, FxValidation, FxValidatorService } from '@instantsys-labs/fx';\r\nimport { FxBuilderWrapperService } from '../../fx-builder-wrapper.service';\r\nimport { CalendarModule } from 'primeng/calendar';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { ApiServiceRegistry } from '@instantsys-labs/core'\r\nimport { TitleStrategy } from '@angular/router';\r\n\r\n@Component({\r\n  selector: 'dropdown-with-other',\r\n  standalone: true,\r\n  imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent, CalendarModule],\r\n  templateUrl: './dropdown-with-other.component.html',\r\n  styleUrl: './dropdown-with-other.component.css'\r\n})\r\nexport class DropdownWithOtherComponent extends FxBaseComponent implements OnInit, AfterViewInit {\r\nprivate fb = inject(FormBuilder);\r\nprivate destroy$ = new Subject<Boolean>();\r\nformObject: object = {};\r\ndropdownMap = new Map<string, any>();\r\n@ViewChild('fxComponent') fxComponent!: FxComponent;\r\n// options = [\r\n//       { optionValue: 'Clinical Notes 1', optionName: 'Clinical Notes 1' },\r\n//       { optionValue: 'Clinical Notes 2', optionName: 'Clinical Notes 2' },\r\n//       { optionValue: 'Clinical Notes 3', optionName: 'Clinical Notes 3' },\r\n//       { optionValue: 'other', optionName: 'Other' }\r\n// ];\r\n\r\noptions: any[] = [];\r\n\r\n     public dropDownForm: FormGroup = this.fb.group({\r\n     selectedOption:[''],\r\n     otherInput: [{ value: '', disabled: true }],\r\n});\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.dropDownForm);\r\n\r\n          console.log('Registered form:', this.dropDownForm)\r\n          console.log('fxDAta:', this.fxData);\r\n\r\n        });\r\n       \r\n      }\r\n\r\n  ngAfterViewInit(): void {\r\n\r\nsetTimeout(() => {\r\n  const key = this.fxComponent?.fxData?.name;\r\n\r\n  if (key && this.dropdownMap.has(key)) {\r\n    this.dropDownForm.patchValue(this.dropdownMap.get(key));\r\n  }\r\n}, 200);\r\n\r\n       setTimeout(()=>{\r\n     const mainControl = this.dropDownForm.get('selectedOption');\r\n     if(this.setting('isRequired')){\r\n      mainControl?.setValidators([Validators.required]);\r\n      mainControl?.updateValueAndValidity();\r\n     }\r\n    },100)\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('dropdown-with-other')) {\r\n      //     this.formObject = value;\r\n      //    }\r\n      //  }\r\n\r\nfor (const [key, value] of Object.entries(variables) as [string, any][]) {\r\n  if (\r\n    value &&\r\n    typeof value === 'object' &&\r\n    'selectedOption' in value\r\n  ) {\r\n    this.dropdownMap.set(key, value);\r\n  }\r\n}\r\n\r\n  })\r\n\r\n  //  this.dropDownForm.get('selectedOption')?.valueChanges.subscribe(value => {\r\n  //   const otherControl = this.dropDownForm.get('otherInput');\r\n  //   if (value === 'other') {\r\n  //     otherControl?.enable();\r\n  //   } else {\r\n  //     otherControl?.disable();\r\n  //     otherControl?.reset();\r\n  //   }\r\n  // });\r\n  const serviceUrl = this.fxApiService.getServiceUrl(this.setting('serviceName'));\r\n  this.getOptions(serviceUrl,this.setting('clinicalNotesURL'));\r\n\r\n  this.dropDownForm.get('selectedOption')?.valueChanges.subscribe(value => {\r\n  const otherControl = this.dropDownForm.get('otherInput');\r\n\r\n  if (value === 'other') {\r\n    otherControl?.enable();\r\n    otherControl?.setValidators([Validators.required]);\r\n  } else {\r\n    otherControl?.disable();\r\n    otherControl?.reset();\r\n    otherControl?.clearValidators(); //\r\n  }\r\n\r\n  otherControl?.updateValueAndValidity(); //\r\n  otherControl?.markAsTouched();\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: 'Label', value: '' }), \r\n             new FxStringSetting({ key: 'other-label', $title: 'Other Label', value: '' }),\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               new FxStringSetting({ key: 'errorMessageOther', $title: 'Other Error Message', value: 'Other is required' }), \r\n               \r\n          ];\r\n        }\r\n      \r\n        protected validations(): FxValidation[] {\r\n          return [FxValidatorService.required];\r\n        }\r\n\r\ngetOptions(serviceUrl: string, url: string) {\r\n  const finalUrl = serviceUrl + url;\r\n  this.http.get<any[]>(finalUrl).subscribe({\r\n    next: (response:any) => {\r\n      this.options = response?.data;\r\n      this.options.push({ value: 'other', label: 'Other' });\r\n    },\r\n    error: (err) => {\r\n      console.error('Error fetching options', err);\r\n    }\r\n  });\r\n}\r\n}\r\n\r\n\r\n","<fx-component [fxData]=\"fxData\" #fxComponent>\r\n  <div class=\"flex justify-center custom-dropdown\"  [ngClass]=\"setting('customClass')\" *ngIf=\"false\">\r\n  <form [formGroup]=\"dropDownForm\" class=\"flex flex-row gap-4 items-start\">\r\n    \r\n    <!-- Dropdown -->\r\n    <div class=\"flex flex-col w-1/2\">\r\n      <div class=\"relative\">\r\n\r\n      <!-- <label class=\"mb-1 font-semibold text-sm\"></label> -->\r\n      <span  class=\"input-label dark:text-gray-300\">{{ setting('select-label') }}</span>\r\n      <select formControlName=\"selectedOption\" class=\"border p-2 rounded w-full\">\r\n        <option value=\"\">Select</option>\r\n        <option *ngFor=\"let option of options\" [value]=\"option.value\">\r\n          {{ option?.label }}\r\n        </option>\r\n      </select>\r\n       <small *ngIf=\"dropDownForm.get('selectedOption')?.touched && dropDownForm.get('selectedOption')?.errors?.['required']\"\r\n        class=\"text-red-500\">\r\n       {{ setting('errorMessage')}}\r\n      </small>\r\n      </div>\r\n    </div>\r\n\r\n    <!-- Other input (only if 'Other' selected) -->\r\n    <div class=\"flex flex-col w-1/2\">\r\n      <div class=\"relative\">\r\n      <label class=\"input-label dark:text-gray-300\">{{ setting('other-label') }}</label>\r\n      <div class=\"relative\">\r\n      <textarea\r\n        formControlName=\"otherInput\"\r\n        placeholder=\"{{setting('other-placeholder')}}\"\r\n        class=\"border p-2 rounded w-full\"\r\n        rows=\"2\"\r\n      ></textarea>\r\n      </div>\r\n      <small *ngIf=\"dropDownForm.get('otherInput')?.touched && dropDownForm.get('otherInput')?.errors?.['required']\"\r\n        class=\"text-red-500\">\r\n        Other is required.\r\n      </small>\r\n      </div>\r\n    </div>\r\n\r\n    \r\n  </form>\r\n</div>\r\n\r\n<div class=\"custom-dropdown\" [ngClass]=\"setting('customClass')\">\r\n  <form [formGroup]=\"dropDownForm\" class=\"flex gap-4 w-full\">\r\n    \r\n    <!-- Dropdown -->\r\n    <div class=\"flex-1\">\r\n      <label class=\"input-label dark:text-gray-300\">\r\n        {{ setting('select-label') }}\r\n      </label>\r\n      <select\r\n        formControlName=\"selectedOption\"\r\n        class=\"border p-2 rounded w-full\"\r\n      >\r\n        <option value=\"\">Select</option>\r\n        <option *ngFor=\"let option of options\" [value]=\"option.value\">\r\n          {{ option?.label }}\r\n        </option>\r\n      </select>\r\n      <small *ngIf=\"dropDownForm.get('selectedOption')?.touched && dropDownForm.get('selectedOption')?.errors?.['required']\"\r\n        class=\"text-red-500\">\r\n       {{ setting('errorMessage')}}\r\n      </small>\r\n    </div>\r\n\r\n    <!-- Other input -->\r\n    <div class=\"flex-1\">\r\n      <label class=\"input-label dark:text-gray-300\">\r\n        {{ setting('other-label') }}\r\n      </label>\r\n      <textarea\r\n        formControlName=\"otherInput\"\r\n        placeholder=\"{{ setting('other-placeholder') }}\"\r\n        class=\"border p-2 rounded w-full\"\r\n        rows=\"2\"\r\n      ></textarea>\r\n\r\n      <small\r\n        *ngIf=\"dropDownForm.get('otherInput')?.touched && dropDownForm.get('otherInput')?.errors?.['required']\"\r\n        class=\"text-red-500\"\r\n      >\r\n        {{ setting('errorMessageOther')}}\r\n      </small>\r\n    </div>\r\n\r\n  </form>\r\n</div>\r\n\r\n\r\n\r\n</fx-component>\r\n\r\n      <!-- <small *ngIf=\"datePickerForm.get('date')?.touched && datePickerForm.get('date')?.errors?.['required']\"\r\n        class=\"text-red-500\">\r\n        Date is required.\r\n      </small> -->"]}
145
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-with-other.component.js","sourceRoot":"","sources":["../../../../../../projects/fx-builder-wrapper/src/lib/components/dropdown-with-other/dropdown-with-other.component.ts","../../../../../../projects/fx-builder-wrapper/src/lib/components/dropdown-with-other/dropdown-with-other.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { AfterViewInit, ChangeDetectorRef, Component, inject, OnInit, ViewChild } from '@angular/core';\r\nimport { FormBuilder, FormGroup, FormsModule, ReactiveFormsModule, Validators } from '@angular/forms';\r\nimport { FxBaseComponent, FxComponent, FxOptionSetting, FxSelectSetting, FxSetting, FxStringSetting, FxValidation, FxValidatorService } from '@instantsys-labs/fx';\r\nimport { FxBuilderWrapperService } from '../../fx-builder-wrapper.service';\r\nimport { CalendarModule } from 'primeng/calendar';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { ApiServiceRegistry } from '@instantsys-labs/core'\r\nimport { TitleStrategy } from '@angular/router';\r\n\r\n@Component({\r\n  selector: 'dropdown-with-other',\r\n  standalone: true,\r\n  imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent, CalendarModule],\r\n  templateUrl: './dropdown-with-other.component.html',\r\n  styleUrl: './dropdown-with-other.component.css'\r\n})\r\nexport class DropdownWithOtherComponent extends FxBaseComponent implements OnInit, AfterViewInit {\r\nprivate fb = inject(FormBuilder);\r\nprivate destroy$ = new Subject<Boolean>();\r\nformObject: object = {};\r\ndropdownMap = new Map<string, any>();\r\n@ViewChild('fxComponent') fxComponent!: FxComponent;\r\n// options = [\r\n//       { optionValue: 'Clinical Notes 1', optionName: 'Clinical Notes 1' },\r\n//       { optionValue: 'Clinical Notes 2', optionName: 'Clinical Notes 2' },\r\n//       { optionValue: 'Clinical Notes 3', optionName: 'Clinical Notes 3' },\r\n//       { optionValue: 'other', optionName: 'Other' }\r\n// ];\r\n\r\noptions: any[] = [];\r\n\r\n     public dropDownForm: FormGroup = this.fb.group({\r\n     selectedOption:[''],\r\n     otherInput: [{ value: '', disabled: true }],\r\n});\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.dropDownForm);\r\n\r\n          console.log('Registered form:', this.dropDownForm)\r\n          console.log('fxDAta:', this.fxData);\r\n\r\n        });\r\n       \r\n      }\r\n\r\n  ngAfterViewInit(): void {\r\n\r\nsetTimeout(() => {\r\n  const key = this.fxComponent?.fxData?.name;\r\n\r\n  if (key && this.dropdownMap.has(key)) {\r\n    this.dropDownForm.patchValue(this.dropdownMap.get(key));\r\n  }\r\n}, 200);\r\n\r\n       setTimeout(()=>{\r\n     const mainControl = this.dropDownForm.get('selectedOption');\r\n     if(this.setting('isRequired') === 'true'){\r\n      mainControl?.setValidators([Validators.required]);\r\n      mainControl?.updateValueAndValidity();\r\n     }\r\n    },100)\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('dropdown-with-other')) {\r\n      //     this.formObject = value;\r\n      //    }\r\n      //  }\r\n\r\nfor (const [key, value] of Object.entries(variables) as [string, any][]) {\r\n  if (\r\n    value &&\r\n    typeof value === 'object' &&\r\n    'selectedOption' in value\r\n  ) {\r\n    this.dropdownMap.set(key, value);\r\n  }\r\n}\r\n\r\n  })\r\n\r\n  //  this.dropDownForm.get('selectedOption')?.valueChanges.subscribe(value => {\r\n  //   const otherControl = this.dropDownForm.get('otherInput');\r\n  //   if (value === 'other') {\r\n  //     otherControl?.enable();\r\n  //   } else {\r\n  //     otherControl?.disable();\r\n  //     otherControl?.reset();\r\n  //   }\r\n  // });\r\n  const serviceUrl = this.fxApiService.getServiceUrl(this.setting('serviceName'));\r\n  this.getOptions(serviceUrl,this.setting('clinicalNotesURL'));\r\n\r\n  this.dropDownForm.get('selectedOption')?.valueChanges.subscribe(value => {\r\n  const otherControl = this.dropDownForm.get('otherInput');\r\n\r\n  if (value === 'other') {\r\n    otherControl?.enable();\r\n    otherControl?.setValidators([Validators.required]);\r\n  } else {\r\n    otherControl?.disable();\r\n    otherControl?.reset();\r\n    otherControl?.clearValidators(); //\r\n  }\r\n\r\n  otherControl?.updateValueAndValidity(); //\r\n  otherControl?.markAsTouched();\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: 'Label', value: '' }), \r\n             new FxStringSetting({ key: 'other-label', $title: 'Other Label', value: '' }),\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               new FxStringSetting({ key: 'errorMessageOther', $title: 'Other Error Message', value: 'Other is required' }), \r\n               \r\n          ];\r\n        }\r\n      \r\n        protected validations(): FxValidation[] {\r\n          return [FxValidatorService.required];\r\n        }\r\n\r\ngetOptions(serviceUrl: string, url: string) {\r\n  const finalUrl = serviceUrl + url;\r\n  this.http.get<any[]>(finalUrl).subscribe({\r\n    next: (response:any) => {\r\n      this.options = response?.data;\r\n      this.options.push({ value: 'other', label: 'Other' });\r\n    },\r\n    error: (err) => {\r\n      console.error('Error fetching options', err);\r\n    }\r\n  });\r\n}\r\n}\r\n\r\n\r\n","<fx-component [fxData]=\"fxData\" #fxComponent>\r\n  <div class=\"flex justify-center custom-dropdown\"  [ngClass]=\"setting('customClass')\" *ngIf=\"false\">\r\n  <form [formGroup]=\"dropDownForm\" class=\"flex flex-row gap-4 items-start\">\r\n    \r\n    <!-- Dropdown -->\r\n    <div class=\"flex flex-col w-1/2\">\r\n      <div class=\"relative\">\r\n\r\n      <!-- <label class=\"mb-1 font-semibold text-sm\"></label> -->\r\n      <span  class=\"input-label dark:text-gray-300\">{{ setting('select-label') }}</span>\r\n      <select formControlName=\"selectedOption\" class=\"border p-2 rounded w-full\">\r\n        <option value=\"\">Select</option>\r\n        <option *ngFor=\"let option of options\" [value]=\"option.value\">\r\n          {{ option?.label }}\r\n        </option>\r\n      </select>\r\n       <small *ngIf=\"dropDownForm.get('selectedOption')?.touched && dropDownForm.get('selectedOption')?.errors?.['required']\"\r\n        class=\"text-red-500\">\r\n       {{ setting('errorMessage')}}\r\n      </small>\r\n      </div>\r\n    </div>\r\n\r\n    <!-- Other input (only if 'Other' selected) -->\r\n    <div class=\"flex flex-col w-1/2\">\r\n      <div class=\"relative\">\r\n      <label class=\"input-label dark:text-gray-300\">{{ setting('other-label') }}</label>\r\n      <div class=\"relative\">\r\n      <textarea\r\n        formControlName=\"otherInput\"\r\n        placeholder=\"{{setting('other-placeholder')}}\"\r\n        class=\"border p-2 rounded w-full\"\r\n        rows=\"2\"\r\n      ></textarea>\r\n      </div>\r\n      <small *ngIf=\"dropDownForm.get('otherInput')?.touched && dropDownForm.get('otherInput')?.errors?.['required']\"\r\n        class=\"text-red-500\">\r\n        Other is required.\r\n      </small>\r\n      </div>\r\n    </div>\r\n\r\n    \r\n  </form>\r\n</div>\r\n\r\n<div class=\"custom-dropdown\" [ngClass]=\"setting('customClass')\">\r\n  <form [formGroup]=\"dropDownForm\" class=\"flex gap-4 w-full\">\r\n    \r\n    <!-- Dropdown -->\r\n    <div class=\"flex-1\">\r\n      <label class=\"input-label dark:text-gray-300\">\r\n        {{ setting('select-label') }}\r\n      </label>\r\n      <select\r\n        formControlName=\"selectedOption\"\r\n        class=\"border p-2 rounded w-full\"\r\n      >\r\n        <option value=\"\">Select</option>\r\n        <option *ngFor=\"let option of options\" [value]=\"option.value\">\r\n          {{ option?.label }}\r\n        </option>\r\n      </select>\r\n      <small *ngIf=\"dropDownForm.get('selectedOption')?.touched && dropDownForm.get('selectedOption')?.errors?.['required']\"\r\n        class=\"text-red-500\">\r\n       {{ setting('errorMessage')}}\r\n      </small>\r\n    </div>\r\n\r\n    <!-- Other input -->\r\n    <div class=\"flex-1\">\r\n      <label class=\"input-label dark:text-gray-300\">\r\n        {{ setting('other-label') }}\r\n      </label>\r\n      <textarea\r\n        formControlName=\"otherInput\"\r\n        placeholder=\"{{ setting('other-placeholder') }}\"\r\n        class=\"border p-2 rounded w-full\"\r\n        rows=\"2\"\r\n      ></textarea>\r\n\r\n      <small\r\n        *ngIf=\"dropDownForm.get('otherInput')?.touched && dropDownForm.get('otherInput')?.errors?.['required']\"\r\n        class=\"text-red-500\"\r\n      >\r\n        {{ setting('errorMessageOther')}}\r\n      </small>\r\n    </div>\r\n\r\n  </form>\r\n</div>\r\n\r\n\r\n\r\n</fx-component>\r\n\r\n      <!-- <small *ngIf=\"datePickerForm.get('date')?.touched && datePickerForm.get('date')?.errors?.['required']\"\r\n        class=\"text-red-500\">\r\n        Date is required.\r\n      </small> -->"]}
@@ -10,6 +10,7 @@ import { UploaderCheckboxComponent } from '../uploader-checkbox/uploader-checkbo
10
10
  import { DatePickerComponent } from '../date-picker/date-picker.component';
11
11
  import { DropdownWithOtherComponent } from '../dropdown-with-other/dropdown-with-other.component';
12
12
  import { RadioGroupComponent } from '../radio-group/radio-group.component';
13
+ import { MultiselectDropdownComponent } from '../multiselect-dropdown/multiselect-dropdown.component';
13
14
  import * as i0 from "@angular/core";
14
15
  import * as i1 from "../../fx-builder-wrapper.service";
15
16
  export class FxFormWrapperComponent {
@@ -57,7 +58,8 @@ export class FxFormWrapperComponent {
57
58
  { name: 'Uploader with Checkbox', key: 'uploader-checkbox', component: UploaderCheckboxComponent },
58
59
  { name: 'Date Picker', key: 'lib-date-picker', component: DatePickerComponent },
59
60
  { name: 'Smartlist with Other', key: 'dropdown-with-other', component: DropdownWithOtherComponent },
60
- { name: 'Radio Group with Other', key: 'radio-group-custom', component: RadioGroupComponent }
61
+ { name: 'Radio Group with Other', key: 'radio-group-custom', component: RadioGroupComponent },
62
+ { name: 'Multiselect Dropdown', key: 'lib-multiselect-dropdown', component: MultiselectDropdownComponent },
61
63
  ];
62
64
  components.forEach(({ name, key, component }) => {
63
65
  if (!this.fxWrapperService.getComponent(key)) {
@@ -108,4 +110,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
108
110
  }], fxFormSubmit: [{
109
111
  type: Output
110
112
  }] } });
111
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fx-form-component.component.js","sourceRoot":"","sources":["../../../../../../projects/fx-builder-wrapper/src/lib/components/fx-form-component/fx-form-component.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, ViewChild } from '@angular/core';\r\nimport { FxForm, FxFormComponent } from '@instantsys-labs/fx';\r\nimport { DispatchToClinicComponent } from '../../custom-controls/dispatch-to-clinic/dispatch-to-clinic.component';\r\nimport { FxBuilderWrapperService } from '../../fx-builder-wrapper.service';\r\nimport { DynamicTableComponent } from '../dynamic-table/dynamic-table.component';\r\nimport { ToggleButtonComponent } from '../toggle-button/toggle-button.component';\r\nimport { UploaderComponent } from '../uploader/uploader.component';\r\nimport { ToggleComponent } from '../toggle/toggle.component';\r\nimport { UploaderCheckboxComponent } from '../uploader-checkbox/uploader-checkbox.component';\r\nimport { DatePickerComponent } from '../date-picker/date-picker.component';\r\nimport { DropdownWithOtherComponent } from '../dropdown-with-other/dropdown-with-other.component';\r\nimport { RadioGroupComponent } from '../radio-group/radio-group.component';\r\n\r\n@Component({\r\n  selector: 'fx-form-component',\r\n  standalone: true,\r\n  imports: [CommonModule, FxFormComponent],\r\n  template: `\r\n    <fx-form \r\n      [fxForm]=\"fxForm\" \r\n      [value]=\"variables\" \r\n      (onSubmit)=\"onSubmit($event)\" \r\n      #form\r\n    >\r\n    </fx-form>\r\n  `,\r\n})\r\nexport class FxFormWrapperComponent implements OnChanges, OnInit {\r\n  @ViewChild('form') form!: FxFormComponent;\r\n  @Input() fxForm!: FxForm;\r\n  @Input() variables: any;\r\n  @Output() fxFormSubmit = new EventEmitter<any>();\r\n\r\n  constructor(private fxWrapperService: FxBuilderWrapperService) {\r\n    this.registerCustomComponents();\r\n   }\r\n\r\n  public ngOnChanges(changes: SimpleChanges): void { \r\n    // if('variables' in changes && !changes['fxForm']) {\r\n    //   this.fxWrapperService.variables$.next(this.variables);\r\n    // }\r\n    if ('variables' in changes) {\r\n      this.fxWrapperService.variables$.next(this.variables);\r\n    }\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    // if (!Boolean(this.fxWrapperService.getComponent('dispatch-to-clinic'))) {\r\n    //   this.fxWrapperService.registerCustomComponent('Dispatch To Clinic', 'dispatch-to-clinic', DispatchToClinicComponent);\r\n    // }\r\n    // if (!Boolean(this.fxWrapperService.getComponent('dynamic-table'))) {\r\n    //   this.fxWrapperService.registerCustomComponent('Dynamic Table', 'dynamic-table', DynamicTableComponent);\r\n    // }\r\n    // if (!Boolean(this.fxWrapperService.getComponent('toggle-button'))) {\r\n    //   this.fxWrapperService.registerCustomComponent('Toggle Button', 'toggle-button', ToggleButtonComponent);\r\n    // }\r\n    // if (!Boolean(this.fxWrapperService.getComponent('uploader'))) {\r\n    //   this.fxWrapperService.registerCustomComponent('Uploader', 'uploader', UploaderComponent);\r\n    // }\r\n    // if (!Boolean(this.fxWrapperService.getComponent('toggle'))) {\r\n    //   this.fxWrapperService.registerCustomComponent('Toggle', 'toggle', ToggleComponent);\r\n    // }\r\n  }\r\n\r\n\r\n  private registerCustomComponents(): void {\r\n    const components = [\r\n      { name: 'Dispatch To Clinic', key: 'dispatch-to-clinic', component: DispatchToClinicComponent },\r\n      { name: 'Dynamic Table', key: 'dynamic-table', component: DynamicTableComponent },\r\n      { name: 'Toggle Button', key: 'toggle-button', component: ToggleButtonComponent },\r\n      { name: 'Uploader', key: 'uploader', component: UploaderComponent },\r\n      { name: 'Toggle', key: 'toggle', component: ToggleComponent },\r\n      { name: 'Uploader with Checkbox', key: 'uploader-checkbox', component: UploaderCheckboxComponent },\r\n      { name: 'Date Picker', key: 'lib-date-picker', component: DatePickerComponent },\r\n       { name: 'Smartlist with Other', key: 'dropdown-with-other', component: DropdownWithOtherComponent },\r\n       { name: 'Radio Group with Other', key: 'radio-group-custom', component: RadioGroupComponent }\r\n    ];\r\n    \r\n    components.forEach(({ name, key, component }) => {\r\n      if (!this.fxWrapperService.getComponent(key)) {\r\n        this.fxWrapperService.registerCustomComponent(name, key, component);\r\n      }\r\n    });\r\n  }\r\n\r\n  public onSubmit(event: any): void {\r\n    this.fxFormSubmit.emit(event);\r\n  }\r\n\r\n  public submit(): void {\r\n    this.form.submit();\r\n  }\r\n}\r\n"]}
113
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fx-form-component.component.js","sourceRoot":"","sources":["../../../../../../projects/fx-builder-wrapper/src/lib/components/fx-form-component/fx-form-component.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, ViewChild } from '@angular/core';\r\nimport { FxForm, FxFormComponent } from '@instantsys-labs/fx';\r\nimport { DispatchToClinicComponent } from '../../custom-controls/dispatch-to-clinic/dispatch-to-clinic.component';\r\nimport { FxBuilderWrapperService } from '../../fx-builder-wrapper.service';\r\nimport { DynamicTableComponent } from '../dynamic-table/dynamic-table.component';\r\nimport { ToggleButtonComponent } from '../toggle-button/toggle-button.component';\r\nimport { UploaderComponent } from '../uploader/uploader.component';\r\nimport { ToggleComponent } from '../toggle/toggle.component';\r\nimport { UploaderCheckboxComponent } from '../uploader-checkbox/uploader-checkbox.component';\r\nimport { DatePickerComponent } from '../date-picker/date-picker.component';\r\nimport { DropdownWithOtherComponent } from '../dropdown-with-other/dropdown-with-other.component';\r\nimport { RadioGroupComponent } from '../radio-group/radio-group.component';\r\nimport { MultiselectDropdownComponent } from '../multiselect-dropdown/multiselect-dropdown.component';\r\n\r\n@Component({\r\n  selector: 'fx-form-component',\r\n  standalone: true,\r\n  imports: [CommonModule, FxFormComponent],\r\n  template: `\r\n    <fx-form \r\n      [fxForm]=\"fxForm\" \r\n      [value]=\"variables\" \r\n      (onSubmit)=\"onSubmit($event)\" \r\n      #form\r\n    >\r\n    </fx-form>\r\n  `,\r\n})\r\nexport class FxFormWrapperComponent implements OnChanges, OnInit {\r\n  @ViewChild('form') form!: FxFormComponent;\r\n  @Input() fxForm!: FxForm;\r\n  @Input() variables: any;\r\n  @Output() fxFormSubmit = new EventEmitter<any>();\r\n\r\n  constructor(private fxWrapperService: FxBuilderWrapperService) {\r\n    this.registerCustomComponents();\r\n   }\r\n\r\n  public ngOnChanges(changes: SimpleChanges): void { \r\n    // if('variables' in changes && !changes['fxForm']) {\r\n    //   this.fxWrapperService.variables$.next(this.variables);\r\n    // }\r\n    if ('variables' in changes) {\r\n      this.fxWrapperService.variables$.next(this.variables);\r\n    }\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    // if (!Boolean(this.fxWrapperService.getComponent('dispatch-to-clinic'))) {\r\n    //   this.fxWrapperService.registerCustomComponent('Dispatch To Clinic', 'dispatch-to-clinic', DispatchToClinicComponent);\r\n    // }\r\n    // if (!Boolean(this.fxWrapperService.getComponent('dynamic-table'))) {\r\n    //   this.fxWrapperService.registerCustomComponent('Dynamic Table', 'dynamic-table', DynamicTableComponent);\r\n    // }\r\n    // if (!Boolean(this.fxWrapperService.getComponent('toggle-button'))) {\r\n    //   this.fxWrapperService.registerCustomComponent('Toggle Button', 'toggle-button', ToggleButtonComponent);\r\n    // }\r\n    // if (!Boolean(this.fxWrapperService.getComponent('uploader'))) {\r\n    //   this.fxWrapperService.registerCustomComponent('Uploader', 'uploader', UploaderComponent);\r\n    // }\r\n    // if (!Boolean(this.fxWrapperService.getComponent('toggle'))) {\r\n    //   this.fxWrapperService.registerCustomComponent('Toggle', 'toggle', ToggleComponent);\r\n    // }\r\n  }\r\n\r\n\r\n  private registerCustomComponents(): void {\r\n    const components = [\r\n      { name: 'Dispatch To Clinic', key: 'dispatch-to-clinic', component: DispatchToClinicComponent },\r\n      { name: 'Dynamic Table', key: 'dynamic-table', component: DynamicTableComponent },\r\n      { name: 'Toggle Button', key: 'toggle-button', component: ToggleButtonComponent },\r\n      { name: 'Uploader', key: 'uploader', component: UploaderComponent },\r\n      { name: 'Toggle', key: 'toggle', component: ToggleComponent },\r\n      { name: 'Uploader with Checkbox', key: 'uploader-checkbox', component: UploaderCheckboxComponent },\r\n      { name: 'Date Picker', key: 'lib-date-picker', component: DatePickerComponent },\r\n       { name: 'Smartlist with Other', key: 'dropdown-with-other', component: DropdownWithOtherComponent },\r\n       { name: 'Radio Group with Other', key: 'radio-group-custom', component: RadioGroupComponent },\r\n       { name: 'Multiselect Dropdown', key: 'lib-multiselect-dropdown', component: MultiselectDropdownComponent },\r\n    ];\r\n    \r\n    components.forEach(({ name, key, component }) => {\r\n      if (!this.fxWrapperService.getComponent(key)) {\r\n        this.fxWrapperService.registerCustomComponent(name, key, component);\r\n      }\r\n    });\r\n  }\r\n\r\n  public onSubmit(event: any): void {\r\n    this.fxFormSubmit.emit(event);\r\n  }\r\n\r\n  public submit(): void {\r\n    this.form.submit();\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,122 @@
1
+ import { Component, inject, ViewChild } from '@angular/core';
2
+ import { FormBuilder, FormsModule, ReactiveFormsModule, Validators } from '@angular/forms';
3
+ import { FxComponent, FxStringSetting, FxSelectSetting, FxBaseComponent, FxOptionSetting } from '@instantsys-labs/fx';
4
+ import { Subject, takeUntil } from 'rxjs';
5
+ import { CommonModule } from '@angular/common';
6
+ import { CalendarModule } from 'primeng/calendar';
7
+ import { MultiSelectModule } from 'primeng/multiselect';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "@angular/common/http";
10
+ import * as i2 from "../../fx-builder-wrapper.service";
11
+ import * as i3 from "@instantsys-labs/core";
12
+ import * as i4 from "@angular/common";
13
+ import * as i5 from "@angular/forms";
14
+ import * as i6 from "primeng/api";
15
+ import * as i7 from "primeng/multiselect";
16
+ export class MultiselectDropdownComponent extends FxBaseComponent {
17
+ cdr;
18
+ http;
19
+ fxBuilderWrapperService;
20
+ fxApiService;
21
+ fb = inject(FormBuilder);
22
+ destroy$ = new Subject();
23
+ formObject = {};
24
+ multiselectDropdownMap = new Map();
25
+ fxComponent;
26
+ options = [];
27
+ multiselectDropDownForm = this.fb.group({
28
+ multipleSelectedOption: [[]],
29
+ });
30
+ constructor(cdr, http, fxBuilderWrapperService, fxApiService) {
31
+ super(cdr);
32
+ this.cdr = cdr;
33
+ this.http = http;
34
+ this.fxBuilderWrapperService = fxBuilderWrapperService;
35
+ this.fxApiService = fxApiService;
36
+ this.onInit.subscribe(() => {
37
+ this._register(this.multiselectDropDownForm);
38
+ });
39
+ }
40
+ ngAfterViewInit() {
41
+ if (!this.setting('multiSelectOptionAPIURL')) {
42
+ this.options = this.fxComponent?.fxData?.settings?.find((s) => s.key === 'itemsOption')?.options || [];
43
+ }
44
+ setTimeout(() => {
45
+ const key = this.fxComponent?.fxData?.name;
46
+ if (key && this.multiselectDropdownMap.has(key)) {
47
+ this.multiselectDropDownForm.patchValue(this.multiselectDropdownMap.get(key));
48
+ }
49
+ }, 200);
50
+ setTimeout(() => {
51
+ const mainControl = this.multiselectDropDownForm.get('multipleSelectedOption');
52
+ if (this.setting('isMultiRequired') === 'true') {
53
+ mainControl?.setValidators([Validators.required]);
54
+ mainControl?.updateValueAndValidity();
55
+ }
56
+ }, 100);
57
+ }
58
+ ngOnInit() {
59
+ this.fxBuilderWrapperService.variables$
60
+ .pipe(takeUntil(this.destroy$))
61
+ .subscribe((variables) => {
62
+ if (!variables)
63
+ return;
64
+ // for (const [key, value] of Object.entries(variables) as [string, any][]) {
65
+ // if (key.includes('dropdown-with-other')) {
66
+ // this.formObject = value;
67
+ // }
68
+ // }
69
+ for (const [key, value] of Object.entries(variables)) {
70
+ if (value &&
71
+ typeof value === 'object' &&
72
+ 'multipleSelectedOption' in value) {
73
+ this.multiselectDropdownMap.set(key, value);
74
+ }
75
+ }
76
+ });
77
+ const serviceUrl = this.fxApiService.getServiceUrl(this.setting('serviceMultiName'));
78
+ this.getOptions(serviceUrl, this.setting('multiSelectOptionAPIURL'));
79
+ }
80
+ settings() {
81
+ return [
82
+ new FxOptionSetting({ key: 'itemsOption', $title: 'Options', value: [{ option: 'Yes', value: 'yes' }, { option: 'No', value: 'no' }] }, [{ option: 'Yes', value: 'yes' }, { option: 'No', value: 'no' }]),
83
+ new FxStringSetting({ key: 'multiSelectOptionAPIURL', $title: 'API Url', value: '' }),
84
+ new FxStringSetting({ key: 'customClassMulti', $title: 'Custom Class Name', value: '' }),
85
+ new FxStringSetting({ key: 'select-label-multi', $title: 'Label', value: '' }),
86
+ new FxStringSetting({ key: 'label-key', $title: 'Label Key', value: 'option' }),
87
+ new FxSelectSetting({ key: 'serviceMultiName', $title: 'Service', value: '' }, [{ option: 'User Service', value: 'user_service' }, { option: 'Patient Service', value: 'patient_service' }, { option: 'Workflow Service', value: 'workflow_service' }]),
88
+ new FxSelectSetting({ key: 'isMultiRequired', $title: 'Required', value: 'true' }, [{ option: 'Yes', value: 'true' }, { option: 'No', value: 'false' }]),
89
+ new FxStringSetting({ key: 'multiErrorMessage', $title: 'Error Message', value: 'Please select' }),
90
+ new FxStringSetting({ key: 'placeholderMulti', $title: 'Placeholder', value: 'Select' }),
91
+ ];
92
+ }
93
+ validations() {
94
+ return [];
95
+ }
96
+ getOptions(serviceUrl, url) {
97
+ if (url) {
98
+ const finalUrl = serviceUrl + url;
99
+ this.http.get(finalUrl).subscribe({
100
+ next: (response) => {
101
+ this.options = response?.data;
102
+ },
103
+ error: (err) => {
104
+ console.error('Error fetching options', err);
105
+ }
106
+ });
107
+ }
108
+ else {
109
+ this.options = this.fxComponent?.fxData?.settings?.find((s) => s.key === 'itemsOption')?.options || [];
110
+ }
111
+ }
112
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MultiselectDropdownComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.HttpClient }, { token: i2.FxBuilderWrapperService }, { token: i3.ApiServiceRegistry }], target: i0.ɵɵFactoryTarget.Component });
113
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: MultiselectDropdownComponent, isStandalone: true, selector: "lib-multiselect-dropdown", viewQueries: [{ propertyName: "fxComponent", first: true, predicate: ["fxComponent"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<fx-component [fxData]=\"fxData\" #fxComponent>\r\n\r\n\r\n <div class=\"custom-dropdown\" [ngClass]=\"setting('customClassMulti')\">\r\n <form [formGroup]=\"multiselectDropDownForm\" class=\"flex gap-4 w-full\">\r\n <div class=\"flex-1\">\r\n <label class=\"input-label dark:text-gray-300\">\r\n {{ setting('select-label-multi') }}\r\n </label>\r\n <p-multiSelect [options]=\"options\" formControlName=\"multipleSelectedOption\" [optionLabel]=\"setting('label-key')\"\r\n [placeholder]=\"setting('placeholderMulti')\" class=\"multiselect\">\r\n\r\n <!-- Custom Dropdown Icon -->\r\n <ng-template pTemplate=\"dropdownicon\">\r\n <div class=\"flex align-items-center dd_down_icon\">\r\n <span class=\"pi pi-angle-down text-xl\"></span>\r\n </div>\r\n </ng-template>\r\n </p-multiSelect>\r\n <small\r\n *ngIf=\"multiselectDropDownForm.get('multipleSelectedOption')?.touched && multiselectDropDownForm.get('multipleSelectedOption')?.errors?.['required']\"\r\n class=\"text-red-500\">\r\n {{ setting('multiErrorMessage')}}\r\n </small>\r\n </div>\r\n </form>\r\n </div>\r\n</fx-component>", styles: ["@import\"https://unpkg.com/primeng@17.18.10/resources/themes/lara-light-blue/theme.css\";@import\"https://unpkg.com/primeng@17.18.10/resources/primeng.min.css\";@import\"https://unpkg.com/primeicons@6.0.0/primeicons.css\";::ng-deep .p-multiselect.p-component.p-inputwrapper{height:37.6px!important;border:1px solid #cdcdcd!important;width:100%!important}.dd_down_icon span{color:#f3a041}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { 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.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: "directive", type: i6.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "ngmodule", type: MultiSelectModule }, { kind: "component", type: i7.MultiSelect, selector: "p-multiSelect", inputs: ["id", "ariaLabel", "style", "styleClass", "panelStyle", "panelStyleClass", "inputId", "disabled", "readonly", "group", "filter", "filterPlaceHolder", "filterLocale", "overlayVisible", "tabindex", "variant", "appendTo", "dataKey", "name", "ariaLabelledBy", "displaySelectedLabel", "maxSelectedLabels", "selectionLimit", "selectedItemsLabel", "showToggleAll", "emptyFilterMessage", "emptyMessage", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "showHeader", "filterBy", "scrollHeight", "lazy", "virtualScroll", "loading", "virtualScrollItemSize", "loadingIcon", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "display", "autocomplete", "showClear", "autofocus", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "defaultLabel", "placeholder", "options", "filterValue", "itemSize", "selectAll", "focusOnHover", "filterFields", "selectOnFocus", "autoOptionFocus"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onClear", "onPanelShow", "onPanelHide", "onLazyLoad", "onRemove", "onSelectAllChange"] }] });
114
+ }
115
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MultiselectDropdownComponent, decorators: [{
116
+ type: Component,
117
+ args: [{ selector: 'lib-multiselect-dropdown', standalone: true, imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent, CalendarModule, MultiSelectModule], template: "<fx-component [fxData]=\"fxData\" #fxComponent>\r\n\r\n\r\n <div class=\"custom-dropdown\" [ngClass]=\"setting('customClassMulti')\">\r\n <form [formGroup]=\"multiselectDropDownForm\" class=\"flex gap-4 w-full\">\r\n <div class=\"flex-1\">\r\n <label class=\"input-label dark:text-gray-300\">\r\n {{ setting('select-label-multi') }}\r\n </label>\r\n <p-multiSelect [options]=\"options\" formControlName=\"multipleSelectedOption\" [optionLabel]=\"setting('label-key')\"\r\n [placeholder]=\"setting('placeholderMulti')\" class=\"multiselect\">\r\n\r\n <!-- Custom Dropdown Icon -->\r\n <ng-template pTemplate=\"dropdownicon\">\r\n <div class=\"flex align-items-center dd_down_icon\">\r\n <span class=\"pi pi-angle-down text-xl\"></span>\r\n </div>\r\n </ng-template>\r\n </p-multiSelect>\r\n <small\r\n *ngIf=\"multiselectDropDownForm.get('multipleSelectedOption')?.touched && multiselectDropDownForm.get('multipleSelectedOption')?.errors?.['required']\"\r\n class=\"text-red-500\">\r\n {{ setting('multiErrorMessage')}}\r\n </small>\r\n </div>\r\n </form>\r\n </div>\r\n</fx-component>", styles: ["@import\"https://unpkg.com/primeng@17.18.10/resources/themes/lara-light-blue/theme.css\";@import\"https://unpkg.com/primeng@17.18.10/resources/primeng.min.css\";@import\"https://unpkg.com/primeicons@6.0.0/primeicons.css\";::ng-deep .p-multiselect.p-component.p-inputwrapper{height:37.6px!important;border:1px solid #cdcdcd!important;width:100%!important}.dd_down_icon span{color:#f3a041}\n"] }]
118
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.HttpClient }, { type: i2.FxBuilderWrapperService }, { type: i3.ApiServiceRegistry }], propDecorators: { fxComponent: [{
119
+ type: ViewChild,
120
+ args: ['fxComponent']
121
+ }] } });
122
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multiselect-dropdown.component.js","sourceRoot":"","sources":["../../../../../../projects/fx-builder-wrapper/src/lib/components/multiselect-dropdown/multiselect-dropdown.component.ts","../../../../../../projects/fx-builder-wrapper/src/lib/components/multiselect-dropdown/multiselect-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\r\nimport { AfterViewInit, ChangeDetectorRef, Component, inject, OnInit, ViewChild } from '@angular/core';\r\nimport { FormBuilder, FormGroup, FormsModule, ReactiveFormsModule, Validators } from '@angular/forms';\r\nimport { FxComponent, FxSetting, FxStringSetting, FxSelectSetting, FxValidation, FxValidatorService, FxBaseComponent, FxOptionSetting } from '@instantsys-labs/fx';\r\nimport { FxBuilderWrapperService } from '../../fx-builder-wrapper.service';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { ApiServiceRegistry } from '@instantsys-labs/core'\r\nimport { CommonModule } from '@angular/common';\r\nimport { CalendarModule } from 'primeng/calendar';\r\nimport { MultiSelectModule } from 'primeng/multiselect';\r\n\r\n@Component({\r\n  selector: 'lib-multiselect-dropdown',\r\n  standalone: true,\r\n  imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent, CalendarModule, MultiSelectModule],\r\n  templateUrl: './multiselect-dropdown.component.html',\r\n  styleUrl: './multiselect-dropdown.component.css'\r\n})\r\nexport class MultiselectDropdownComponent extends FxBaseComponent implements OnInit, AfterViewInit {\r\n\r\n  private fb = inject(FormBuilder);\r\n  private destroy$ = new Subject<Boolean>();\r\n  formObject: object = {};\r\n  multiselectDropdownMap = new Map<string, any>();\r\n  @ViewChild('fxComponent') fxComponent!: FxComponent;\r\n \r\n  options: any[] = [];\r\n\r\n  public multiselectDropDownForm: FormGroup = this.fb.group({\r\n    multipleSelectedOption: [[]],\r\n  });\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.multiselectDropDownForm);\r\n    });\r\n\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n\r\n    if (!this.setting('multiSelectOptionAPIURL')) {\r\n      this.options = (this.fxComponent?.fxData?.settings?.find((s: any) => s.key === 'itemsOption') as any)?.options || [];\r\n    }\r\n\r\n    setTimeout(() => {\r\n      const key = this.fxComponent?.fxData?.name;\r\n\r\n      if (key && this.multiselectDropdownMap.has(key)) {\r\n        this.multiselectDropDownForm.patchValue(this.multiselectDropdownMap.get(key));\r\n      }\r\n    }, 200);\r\n\r\n    setTimeout(() => {\r\n      const mainControl = this.multiselectDropDownForm.get('multipleSelectedOption');\r\n      if (this.setting('isMultiRequired') === 'true') {\r\n        mainControl?.setValidators([Validators.required]);\r\n        mainControl?.updateValueAndValidity();\r\n      }\r\n    }, 100)\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('dropdown-with-other')) {\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            'multipleSelectedOption' in value\r\n          ) {\r\n            this.multiselectDropdownMap.set(key, value);\r\n          }\r\n        }\r\n\r\n      })\r\n\r\n    const serviceUrl = this.fxApiService.getServiceUrl(this.setting('serviceMultiName'));\r\n    this.getOptions(serviceUrl, this.setting('multiSelectOptionAPIURL'));\r\n  }\r\n\r\n  protected settings(): FxSetting[] {\r\n    return [\r\n      new FxOptionSetting({ key: 'itemsOption', $title: 'Options', value: [{ option: 'Yes', value: 'yes' }, { option: 'No', value: 'no' }] }, [{ option: 'Yes', value: 'yes' }, { option: 'No', value: 'no' }]),\r\n      new FxStringSetting({ key: 'multiSelectOptionAPIURL', $title: 'API Url', value: '' }),\r\n      new FxStringSetting({ key: 'customClassMulti', $title: 'Custom Class Name', value: '' }),\r\n      new FxStringSetting({ key: 'select-label-multi', $title: 'Label', value: '' }),\r\n      new FxStringSetting({ key: 'label-key', $title: 'Label Key', value: 'option' }),\r\n      new FxSelectSetting({ key: 'serviceMultiName', $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: 'isMultiRequired', $title: 'Required', value: 'true' }, [{ option: 'Yes', value: 'true' }, { option: 'No', value: 'false' }]),\r\n      new FxStringSetting({ key: 'multiErrorMessage', $title: 'Error Message', value: 'Please select' }),\r\n      new FxStringSetting({ key: 'placeholderMulti', $title: 'Placeholder', value: 'Select' }),\r\n    ];\r\n  }\r\n\r\n  protected validations(): FxValidation[] {\r\n    return [];\r\n  }\r\n\r\n  getOptions(serviceUrl: string, url: string) {\r\n    if (url) {\r\n      const finalUrl = serviceUrl + url;\r\n      this.http.get<any[]>(finalUrl).subscribe({\r\n        next: (response: any) => {\r\n          this.options = response?.data;\r\n        },\r\n        error: (err) => {\r\n          console.error('Error fetching options', err);\r\n        }\r\n      });\r\n    } else {\r\n      this.options = (this.fxComponent?.fxData?.settings?.find((s: any) => s.key === 'itemsOption') as any)?.options || [];\r\n    }\r\n  }\r\n\r\n}\r\n","<fx-component [fxData]=\"fxData\" #fxComponent>\r\n\r\n\r\n  <div class=\"custom-dropdown\" [ngClass]=\"setting('customClassMulti')\">\r\n    <form [formGroup]=\"multiselectDropDownForm\" class=\"flex gap-4 w-full\">\r\n      <div class=\"flex-1\">\r\n        <label class=\"input-label dark:text-gray-300\">\r\n          {{ setting('select-label-multi') }}\r\n        </label>\r\n        <p-multiSelect [options]=\"options\" formControlName=\"multipleSelectedOption\" [optionLabel]=\"setting('label-key')\"\r\n          [placeholder]=\"setting('placeholderMulti')\" class=\"multiselect\">\r\n\r\n          <!-- Custom Dropdown Icon -->\r\n          <ng-template pTemplate=\"dropdownicon\">\r\n            <div class=\"flex align-items-center dd_down_icon\">\r\n              <span class=\"pi pi-angle-down text-xl\"></span>\r\n            </div>\r\n          </ng-template>\r\n        </p-multiSelect>\r\n        <small\r\n          *ngIf=\"multiselectDropDownForm.get('multipleSelectedOption')?.touched && multiselectDropDownForm.get('multipleSelectedOption')?.errors?.['required']\"\r\n          class=\"text-red-500\">\r\n          {{ setting('multiErrorMessage')}}\r\n        </small>\r\n      </div>\r\n    </form>\r\n  </div>\r\n</fx-component>"]}
@@ -10,6 +10,7 @@ import { UploaderCheckboxComponent } from './components/uploader-checkbox/upload
10
10
  import { DatePickerComponent } from './components/date-picker/date-picker.component';
11
11
  import { DropdownWithOtherComponent } from './components/dropdown-with-other/dropdown-with-other.component';
12
12
  import { RadioGroupComponent } from './components/radio-group/radio-group.component';
13
+ import { MultiselectDropdownComponent } from './components/multiselect-dropdown/multiselect-dropdown.component';
13
14
  import * as i0 from "@angular/core";
14
15
  import * as i1 from "./fx-builder-wrapper.service";
15
16
  export class FxBuilderWrapperComponent {
@@ -55,6 +56,9 @@ export class FxBuilderWrapperComponent {
55
56
  if (!Boolean(this.fxWrapperService.getComponent('radio-group-custom'))) {
56
57
  this.fxWrapperService.registerCustomComponent('Radio Group with Other', 'radio-group-custom', RadioGroupComponent);
57
58
  }
59
+ if (!Boolean(this.fxWrapperService.getComponent('lib-multiselect-dropdown'))) {
60
+ this.fxWrapperService.registerCustomComponent('Multiselect Dropdown', 'lib-multiselect-dropdown', MultiselectDropdownComponent);
61
+ }
58
62
  }
59
63
  ;
60
64
  getParsedForm() {
@@ -92,4 +96,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
92
96
  type: Input,
93
97
  args: [{ alias: 'fx-form', required: true }]
94
98
  }] } });
95
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fx-builder-wrapper.component.js","sourceRoot":"","sources":["../../../../projects/fx-builder-wrapper/src/lib/fx-builder-wrapper.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, Input, OnInit, ViewChild, ViewEncapsulation } from '@angular/core';\r\nimport { FxBuilderConfiguration, FxComponentBuilder, FxForm, FxMode, FxScope, FxUtils } from '@instantsys-labs/fx';\r\nimport { DispatchToClinicComponent } from './custom-controls/dispatch-to-clinic/dispatch-to-clinic.component';\r\nimport { FxBuilderWrapperService } from './fx-builder-wrapper.service';\r\nimport { DynamicTableComponent } from './components/dynamic-table/dynamic-table.component';\r\nimport { ToggleButtonComponent } from './components/toggle-button/toggle-button.component';\r\nimport { UploaderComponent } from './components/uploader/uploader.component';\r\nimport { ToggleComponent } from './components/toggle/toggle.component';\r\nimport { UploaderCheckboxComponent } from './components/uploader-checkbox/uploader-checkbox.component';\r\nimport { DatePickerComponent } from './components/date-picker/date-picker.component';\r\nimport { DropdownWithOtherComponent } from './components/dropdown-with-other/dropdown-with-other.component';\r\nimport { RadioGroupComponent } from './components/radio-group/radio-group.component';\r\n\r\n@Component({\r\n  selector: 'fx-builder-wrapper',\r\n  standalone: true,\r\n  imports: [CommonModule, FxComponentBuilder],\r\n  template: `\r\n    <fx-component-builder \r\n        #componentBuilder \r\n        [fx-form]=\"fxForm\" \r\n        [configuration]=\"fxConfiguration\" \r\n        [scope]=\"FxScope.BUILDER\"\r\n        >\r\n    </fx-component-builder>\r\n  `,\r\n  styleUrl: './form-builder.css',\r\n})\r\nexport class FxBuilderWrapperComponent implements OnInit {\r\n  @ViewChild('componentBuilder') componentBuilder!: FxComponentBuilder;\r\n  @Input({ alias: 'fx-form', required: true }) fxForm: FxForm = FxUtils.createNewForm();\r\n  public fxMode: FxMode = FxMode.EDIT;\r\n  public fxConfiguration: FxBuilderConfiguration = {\r\n    settings: true,\r\n    logics: true,\r\n    customControls: true,\r\n  }\r\n\r\n  protected readonly FxScope = FxScope;\r\n  protected readonly FxMode = FxMode;\r\n\r\n  constructor(private fxWrapperService: FxBuilderWrapperService) { }\r\n\r\n  public ngOnInit(): void {\r\n    if (!Boolean(this.fxWrapperService.getComponent('dispatch-to-clinic'))) {\r\n      this.fxWrapperService.registerCustomComponent('Dispatch To Clinic', 'dispatch-to-clinic', DispatchToClinicComponent);\r\n    }\r\n    if (!Boolean(this.fxWrapperService.getComponent('dynamic-table'))) {\r\n      this.fxWrapperService.registerCustomComponent('Dynamic Table', 'dynamic-table', DynamicTableComponent);\r\n    }\r\n    if (!Boolean(this.fxWrapperService.getComponent('toggle-button'))) {\r\n      this.fxWrapperService.registerCustomComponent('Toggle Button', 'toggle-button', ToggleButtonComponent);\r\n    }\r\n    if (!Boolean(this.fxWrapperService.getComponent('uploader'))) {\r\n      this.fxWrapperService.registerCustomComponent('Uploader', 'uploader', UploaderComponent);\r\n    }\r\n    if (!Boolean(this.fxWrapperService.getComponent('uploader-checkbox'))) {\r\n      this.fxWrapperService.registerCustomComponent('Uploader with Checkbox', 'uploader-checkbox', UploaderCheckboxComponent);\r\n    }\r\n    if (!Boolean(this.fxWrapperService.getComponent('toggle'))) {\r\n      this.fxWrapperService.registerCustomComponent('Toggle', 'toggle', ToggleComponent);\r\n    }\r\n    if (!Boolean(this.fxWrapperService.getComponent('lib-date-picker'))) {\r\n      this.fxWrapperService.registerCustomComponent('Date Picker', 'lib-date-picker', DatePickerComponent);\r\n    }\r\n        if (!Boolean(this.fxWrapperService.getComponent('dropdown-with-other'))) {\r\n      this.fxWrapperService.registerCustomComponent('Smartlist with Other', 'dropdown-with-other', DropdownWithOtherComponent);\r\n    }\r\n       if (!Boolean(this.fxWrapperService.getComponent('radio-group-custom'))) {\r\n      this.fxWrapperService.registerCustomComponent('Radio Group with Other', 'radio-group-custom', RadioGroupComponent);\r\n    }\r\n  };\r\n\r\n  public getParsedForm(): FxForm {\r\n    return this.componentBuilder.getParsedForm();\r\n  }\r\n\r\n  public getInitializedFxForm(): FxForm {\r\n    return FxUtils.createNewForm(); \r\n  }\r\n}\r\n\r\n\r\n"]}
99
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fx-builder-wrapper.component.js","sourceRoot":"","sources":["../../../../projects/fx-builder-wrapper/src/lib/fx-builder-wrapper.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, Input, OnInit, ViewChild, ViewEncapsulation } from '@angular/core';\r\nimport { FxBuilderConfiguration, FxComponentBuilder, FxForm, FxMode, FxScope, FxUtils } from '@instantsys-labs/fx';\r\nimport { DispatchToClinicComponent } from './custom-controls/dispatch-to-clinic/dispatch-to-clinic.component';\r\nimport { FxBuilderWrapperService } from './fx-builder-wrapper.service';\r\nimport { DynamicTableComponent } from './components/dynamic-table/dynamic-table.component';\r\nimport { ToggleButtonComponent } from './components/toggle-button/toggle-button.component';\r\nimport { UploaderComponent } from './components/uploader/uploader.component';\r\nimport { ToggleComponent } from './components/toggle/toggle.component';\r\nimport { UploaderCheckboxComponent } from './components/uploader-checkbox/uploader-checkbox.component';\r\nimport { DatePickerComponent } from './components/date-picker/date-picker.component';\r\nimport { DropdownWithOtherComponent } from './components/dropdown-with-other/dropdown-with-other.component';\r\nimport { RadioGroupComponent } from './components/radio-group/radio-group.component';\r\nimport { MultiselectDropdownComponent } from './components/multiselect-dropdown/multiselect-dropdown.component';\r\n\r\n@Component({\r\n  selector: 'fx-builder-wrapper',\r\n  standalone: true,\r\n  imports: [CommonModule, FxComponentBuilder],\r\n  template: `\r\n    <fx-component-builder \r\n        #componentBuilder \r\n        [fx-form]=\"fxForm\" \r\n        [configuration]=\"fxConfiguration\" \r\n        [scope]=\"FxScope.BUILDER\"\r\n        >\r\n    </fx-component-builder>\r\n  `,\r\n  styleUrl: './form-builder.css',\r\n})\r\nexport class FxBuilderWrapperComponent implements OnInit {\r\n  @ViewChild('componentBuilder') componentBuilder!: FxComponentBuilder;\r\n  @Input({ alias: 'fx-form', required: true }) fxForm: FxForm = FxUtils.createNewForm();\r\n  public fxMode: FxMode = FxMode.EDIT;\r\n  public fxConfiguration: FxBuilderConfiguration = {\r\n    settings: true,\r\n    logics: true,\r\n    customControls: true,\r\n  }\r\n\r\n  protected readonly FxScope = FxScope;\r\n  protected readonly FxMode = FxMode;\r\n\r\n  constructor(private fxWrapperService: FxBuilderWrapperService) { }\r\n\r\n  public ngOnInit(): void {\r\n    if (!Boolean(this.fxWrapperService.getComponent('dispatch-to-clinic'))) {\r\n      this.fxWrapperService.registerCustomComponent('Dispatch To Clinic', 'dispatch-to-clinic', DispatchToClinicComponent);\r\n    }\r\n    if (!Boolean(this.fxWrapperService.getComponent('dynamic-table'))) {\r\n      this.fxWrapperService.registerCustomComponent('Dynamic Table', 'dynamic-table', DynamicTableComponent);\r\n    }\r\n    if (!Boolean(this.fxWrapperService.getComponent('toggle-button'))) {\r\n      this.fxWrapperService.registerCustomComponent('Toggle Button', 'toggle-button', ToggleButtonComponent);\r\n    }\r\n    if (!Boolean(this.fxWrapperService.getComponent('uploader'))) {\r\n      this.fxWrapperService.registerCustomComponent('Uploader', 'uploader', UploaderComponent);\r\n    }\r\n    if (!Boolean(this.fxWrapperService.getComponent('uploader-checkbox'))) {\r\n      this.fxWrapperService.registerCustomComponent('Uploader with Checkbox', 'uploader-checkbox', UploaderCheckboxComponent);\r\n    }\r\n    if (!Boolean(this.fxWrapperService.getComponent('toggle'))) {\r\n      this.fxWrapperService.registerCustomComponent('Toggle', 'toggle', ToggleComponent);\r\n    }\r\n    if (!Boolean(this.fxWrapperService.getComponent('lib-date-picker'))) {\r\n      this.fxWrapperService.registerCustomComponent('Date Picker', 'lib-date-picker', DatePickerComponent);\r\n    }\r\n        if (!Boolean(this.fxWrapperService.getComponent('dropdown-with-other'))) {\r\n      this.fxWrapperService.registerCustomComponent('Smartlist with Other', 'dropdown-with-other', DropdownWithOtherComponent);\r\n    }\r\n       if (!Boolean(this.fxWrapperService.getComponent('radio-group-custom'))) {\r\n      this.fxWrapperService.registerCustomComponent('Radio Group with Other', 'radio-group-custom', RadioGroupComponent);\r\n    }\r\n     if (!Boolean(this.fxWrapperService.getComponent('lib-multiselect-dropdown'))) {\r\n      this.fxWrapperService.registerCustomComponent('Multiselect Dropdown', 'lib-multiselect-dropdown', MultiselectDropdownComponent);\r\n    }\r\n  };\r\n\r\n  public getParsedForm(): FxForm {\r\n    return this.componentBuilder.getParsedForm();\r\n  }\r\n\r\n  public getInitializedFxForm(): FxForm {\r\n    return FxUtils.createNewForm(); \r\n  }\r\n}\r\n\r\n\r\n"]}