fx-form-builder-wrapper 2.0.80 → 2.0.81

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.
@@ -39,8 +39,6 @@ export class DropdownWithOtherComponent extends FxBaseComponent {
39
39
  this.fxApiService = fxApiService;
40
40
  this.onInit.subscribe(() => {
41
41
  this._register(this.dropDownForm);
42
- console.log('Registered form:', this.dropDownForm);
43
- console.log('fxDAta:', this.fxData);
44
42
  });
45
43
  }
46
44
  ngAfterViewInit() {
@@ -97,9 +95,9 @@ export class DropdownWithOtherComponent extends FxBaseComponent {
97
95
  else {
98
96
  otherControl?.disable();
99
97
  otherControl?.reset();
100
- otherControl?.clearValidators(); //
98
+ otherControl?.clearValidators();
101
99
  }
102
- otherControl?.updateValueAndValidity(); //
100
+ otherControl?.updateValueAndValidity();
103
101
  otherControl?.markAsTouched();
104
102
  });
105
103
  }
@@ -111,7 +109,6 @@ export class DropdownWithOtherComponent extends FxBaseComponent {
111
109
  new FxStringSetting({ key: 'other-label', $title: 'Other Label', value: '' }),
112
110
  new FxStringSetting({ key: 'other-placeholder', $title: 'Other Placeholder', value: '' }),
113
111
  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' }]),
114
- // new FxSelectSetting({key: 'service', $title: 'Service', value: 'local'}, [{option: 'Local', value: 'local'}, {option: 'QA', value: 'qa'},{option: 'UAT', value: 'uat'},{option: 'Production', value: 'prod'}]),
115
112
  new FxSelectSetting({ key: 'isRequired', $title: 'Required', value: 'true' }, [{ option: 'Yes', value: 'true' }, { option: 'No', value: 'false' }]),
116
113
  new FxStringSetting({ key: 'errorMessage', $title: 'Error Message', value: 'Please fill out the field' }),
117
114
  new FxStringSetting({ key: 'errorMessageOther', $title: 'Other Error Message', value: 'Other is required' }),
@@ -142,4 +139,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
142
139
  type: ViewChild,
143
140
  args: ['fxComponent']
144
141
  }] } });
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> -->"]}
142
+ //# 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\n  private fb = inject(FormBuilder);\r\n  private destroy$ = new Subject<Boolean>();\r\n  formObject: object = {};\r\n  dropdownMap = 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\n  options: 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\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n\r\n    setTimeout(() => {\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\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            '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: '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\n  getOptions(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> -->"]}
@@ -11,6 +11,7 @@ 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
13
  import { MultiselectDropdownComponent } from '../multiselect-dropdown/multiselect-dropdown.component';
14
+ import { MultiselectDropdownWithChildsComponent } from '../multiselect-dropdown-with-childs/multiselect-dropdown-with-childs.component';
14
15
  import * as i0 from "@angular/core";
15
16
  import * as i1 from "../../fx-builder-wrapper.service";
16
17
  export class FxFormWrapperComponent {
@@ -60,6 +61,7 @@ export class FxFormWrapperComponent {
60
61
  { name: 'Smartlist with Other', key: 'dropdown-with-other', component: DropdownWithOtherComponent },
61
62
  { name: 'Radio Group with Other', key: 'radio-group-custom', component: RadioGroupComponent },
62
63
  { name: 'Multiselect Dropdown', key: 'lib-multiselect-dropdown', component: MultiselectDropdownComponent },
64
+ { name: 'Multiselect Dropdown with Childs', key: 'lib-multiselect-dropdown-with-childs', component: MultiselectDropdownWithChildsComponent },
63
65
  ];
64
66
  components.forEach(({ name, key, component }) => {
65
67
  if (!this.fxWrapperService.getComponent(key)) {
@@ -110,4 +112,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
110
112
  }], fxFormSubmit: [{
111
113
  type: Output
112
114
  }] } });
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"]}
115
+ //# 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\nimport { MultiselectDropdownWithChildsComponent } from '../multiselect-dropdown-with-childs/multiselect-dropdown-with-childs.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       { name: 'Multiselect Dropdown with Childs', key: 'lib-multiselect-dropdown-with-childs', component: MultiselectDropdownWithChildsComponent },\r\n      \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"]}
@@ -110,13 +110,13 @@ export class MultiselectDropdownComponent extends FxBaseComponent {
110
110
  }
111
111
  }
112
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"] }] });
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 <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
114
  }
115
115
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MultiselectDropdownComponent, decorators: [{
116
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"] }]
117
+ args: [{ selector: 'lib-multiselect-dropdown', standalone: true, imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent, CalendarModule, MultiSelectModule], template: "<fx-component [fxData]=\"fxData\" #fxComponent>\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
118
  }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.HttpClient }, { type: i2.FxBuilderWrapperService }, { type: i3.ApiServiceRegistry }], propDecorators: { fxComponent: [{
119
119
  type: ViewChild,
120
120
  args: ['fxComponent']
121
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>"]}
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":"AACA,OAAO,EAAoC,SAAS,EAAE,MAAM,EAAU,SAAS,EAAE,MAAM,eAAe,CAAC;AACvG,OAAO,EAAE,WAAW,EAAa,WAAW,EAAE,mBAAmB,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AACtG,OAAO,EAAE,WAAW,EAAa,eAAe,EAAE,eAAe,EAAoC,eAAe,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAEnK,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAE1C,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;;;;;;;;;AASxD,MAAM,OAAO,4BAA6B,SAAQ,eAAe;IAc3C;IAAgC;IAA0B;IAA0D;IAZhI,EAAE,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;IACzB,QAAQ,GAAG,IAAI,OAAO,EAAW,CAAC;IAC1C,UAAU,GAAW,EAAE,CAAC;IACxB,sBAAsB,GAAG,IAAI,GAAG,EAAe,CAAC;IACtB,WAAW,CAAe;IAEpD,OAAO,GAAU,EAAE,CAAC;IAEb,uBAAuB,GAAc,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;QACxD,sBAAsB,EAAE,CAAC,EAAE,CAAC;KAC7B,CAAC,CAAC;IAEH,YAAoB,GAAsB,EAAU,IAAgB,EAAU,uBAAgD,EAAU,YAAgC;QACtK,KAAK,CAAC,GAAG,CAAC,CAAA;QADQ,QAAG,GAAH,GAAG,CAAmB;QAAU,SAAI,GAAJ,IAAI,CAAY;QAAU,4BAAuB,GAAvB,uBAAuB,CAAyB;QAAU,iBAAY,GAAZ,YAAY,CAAoB;QAEtK,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,EAAE;YACzB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;QAC/C,CAAC,CAAC,CAAC;IAEL,CAAC;IAED,eAAe;QAEb,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,yBAAyB,CAAC,EAAE,CAAC;YAC7C,IAAI,CAAC,OAAO,GAAI,IAAI,CAAC,WAAW,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,aAAa,CAAS,EAAE,OAAO,IAAI,EAAE,CAAC;QACvH,CAAC;QAED,UAAU,CAAC,GAAG,EAAE;YACd,MAAM,GAAG,GAAG,IAAI,CAAC,WAAW,EAAE,MAAM,EAAE,IAAI,CAAC;YAE3C,IAAI,GAAG,IAAI,IAAI,CAAC,sBAAsB,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;gBAChD,IAAI,CAAC,uBAAuB,CAAC,UAAU,CAAC,IAAI,CAAC,sBAAsB,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;YAChF,CAAC;QACH,CAAC,EAAE,GAAG,CAAC,CAAC;QAER,UAAU,CAAC,GAAG,EAAE;YACd,MAAM,WAAW,GAAG,IAAI,CAAC,uBAAuB,CAAC,GAAG,CAAC,wBAAwB,CAAC,CAAC;YAC/E,IAAI,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,KAAK,MAAM,EAAE,CAAC;gBAC/C,WAAW,EAAE,aAAa,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC;gBAClD,WAAW,EAAE,sBAAsB,EAAE,CAAC;YACxC,CAAC;QACH,CAAC,EAAE,GAAG,CAAC,CAAA;IACT,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,uBAAuB,CAAC,UAAU;aACpC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC9B,SAAS,CAAC,CAAC,SAAc,EAAE,EAAE;YAC5B,IAAI,CAAC,SAAS;gBAAE,OAAO;YAGvB,8EAA8E;YAC9E,gDAAgD;YAChD,+BAA+B;YAC/B,OAAO;YACP,KAAK;YAEL,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,SAAS,CAAoB,EAAE,CAAC;gBACxE,IACE,KAAK;oBACL,OAAO,KAAK,KAAK,QAAQ;oBACzB,wBAAwB,IAAI,KAAK,EACjC,CAAC;oBACD,IAAI,CAAC,sBAAsB,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;gBAC9C,CAAC;YACH,CAAC;QAEH,CAAC,CAAC,CAAA;QAEJ,MAAM,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC,CAAC;QACrF,IAAI,CAAC,UAAU,CAAC,UAAU,EAAE,IAAI,CAAC,OAAO,CAAC,yBAAyB,CAAC,CAAC,CAAC;IACvE,CAAC;IAES,QAAQ;QAChB,OAAO;YACL,IAAI,eAAe,CAAC,EAAE,GAAG,EAAE,aAAa,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;YACzM,IAAI,eAAe,CAAC,EAAE,GAAG,EAAE,yBAAyB,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC;YACrF,IAAI,eAAe,CAAC,EAAE,GAAG,EAAE,kBAAkB,EAAE,MAAM,EAAE,mBAAmB,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC;YACxF,IAAI,eAAe,CAAC,EAAE,GAAG,EAAE,oBAAoB,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC;YAC9E,IAAI,eAAe,CAAC,EAAE,GAAG,EAAE,WAAW,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC;YAC/E,IAAI,eAAe,CAAC,EAAE,GAAG,EAAE,kBAAkB,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,MAAM,EAAE,cAAc,EAAE,KAAK,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM,EAAE,iBAAiB,EAAE,KAAK,EAAE,iBAAiB,EAAE,EAAE,EAAE,MAAM,EAAE,kBAAkB,EAAE,KAAK,EAAE,kBAAkB,EAAE,CAAC,CAAC;YACvP,IAAI,eAAe,CAAC,EAAE,GAAG,EAAE,iBAAiB,EAAE,MAAM,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC;YACxJ,IAAI,eAAe,CAAC,EAAE,GAAG,EAAE,mBAAmB,EAAE,MAAM,EAAE,eAAe,EAAE,KAAK,EAAE,eAAe,EAAE,CAAC;YAClG,IAAI,eAAe,CAAC,EAAE,GAAG,EAAE,kBAAkB,EAAE,MAAM,EAAE,aAAa,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC;SACzF,CAAC;IACJ,CAAC;IAES,WAAW;QACnB,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,UAAU,CAAC,UAAkB,EAAE,GAAW;QACxC,IAAI,GAAG,EAAE,CAAC;YACR,MAAM,QAAQ,GAAG,UAAU,GAAG,GAAG,CAAC;YAClC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAQ,QAAQ,CAAC,CAAC,SAAS,CAAC;gBACvC,IAAI,EAAE,CAAC,QAAa,EAAE,EAAE;oBACtB,IAAI,CAAC,OAAO,GAAG,QAAQ,EAAE,IAAI,CAAC;gBAChC,CAAC;gBACD,KAAK,EAAE,CAAC,GAAG,EAAE,EAAE;oBACb,OAAO,CAAC,KAAK,CAAC,wBAAwB,EAAE,GAAG,CAAC,CAAC;gBAC/C,CAAC;aACF,CAAC,CAAC;QACL,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,OAAO,GAAI,IAAI,CAAC,WAAW,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,aAAa,CAAS,EAAE,OAAO,IAAI,EAAE,CAAC;QACvH,CAAC;IACH,CAAC;wGA1GU,4BAA4B;4FAA5B,4BAA4B,uNClBzC,6tCAyBe,8bDXH,YAAY,gOAAE,mBAAmB,4rBAAE,WAAW,+BAAE,WAAW,4EAAE,cAAc,qIAAE,iBAAiB;;4FAI7F,4BAA4B;kBAPxC,SAAS;+BACE,0BAA0B,cACxB,IAAI,WACP,CAAC,YAAY,EAAE,mBAAmB,EAAE,WAAW,EAAE,WAAW,EAAE,cAAc,EAAE,iBAAiB,CAAC;sLAU/E,WAAW;sBAApC,SAAS;uBAAC,aAAa","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  <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>"]}
@@ -0,0 +1,150 @@
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 MultiselectDropdownWithChildsComponent extends FxBaseComponent {
17
+ cdr;
18
+ http;
19
+ fxBuilderWrapperService;
20
+ fxApiService;
21
+ fb = inject(FormBuilder);
22
+ destroy$ = new Subject();
23
+ formObject = {};
24
+ multiChildDropdownMap = new Map();
25
+ fxComponent;
26
+ options = [];
27
+ multiChildDropDownForm = this.fb.group({
28
+ multipleChildSelectedOption: [[]],
29
+ child1: [''],
30
+ child2: [''],
31
+ child1Label: [''],
32
+ child2Label: [''],
33
+ });
34
+ constructor(cdr, http, fxBuilderWrapperService, fxApiService) {
35
+ super(cdr);
36
+ this.cdr = cdr;
37
+ this.http = http;
38
+ this.fxBuilderWrapperService = fxBuilderWrapperService;
39
+ this.fxApiService = fxApiService;
40
+ this.onInit.subscribe(() => {
41
+ this._register(this.multiChildDropDownForm);
42
+ });
43
+ }
44
+ ngAfterViewInit() {
45
+ if (!this.setting('multiChildOptionAPIURL')) {
46
+ this.options = this.fxComponent?.fxData?.settings?.find((s) => s.key === 'itemsChildOption')?.options || [];
47
+ }
48
+ const child1LabelControl = this.multiChildDropDownForm.get('child1Label');
49
+ const child2LabelControl = this.multiChildDropDownForm.get('child2Label');
50
+ child1LabelControl?.setValue(this.setting('child-1-label'));
51
+ child2LabelControl?.setValue(this.setting('child-2-label'));
52
+ child1LabelControl?.updateValueAndValidity();
53
+ child2LabelControl?.updateValueAndValidity();
54
+ setTimeout(() => {
55
+ const key = this.fxComponent?.fxData?.name;
56
+ if (key && this.multiChildDropdownMap.has(key)) {
57
+ this.multiChildDropDownForm.patchValue(this.multiChildDropdownMap.get(key));
58
+ }
59
+ }, 200);
60
+ setTimeout(() => {
61
+ const mainControl = this.multiChildDropDownForm.get('multipleChildSelectedOption');
62
+ const child1Control = this.multiChildDropDownForm.get('child1');
63
+ const child2Control = this.multiChildDropDownForm.get('child2');
64
+ if (this.setting('isMultiChildRequired') === 'true') {
65
+ mainControl?.setValidators([Validators.required]);
66
+ mainControl?.updateValueAndValidity();
67
+ }
68
+ if (this.setting('isChild1Required') === 'true') {
69
+ child1Control?.setValidators([Validators.required]);
70
+ child1Control?.updateValueAndValidity();
71
+ }
72
+ if (this.setting('isChild2Required') === 'true') {
73
+ child2Control?.setValidators([Validators.required]);
74
+ child2Control?.updateValueAndValidity();
75
+ }
76
+ }, 1000);
77
+ }
78
+ ngOnInit() {
79
+ this.fxBuilderWrapperService.variables$
80
+ .pipe(takeUntil(this.destroy$))
81
+ .subscribe((variables) => {
82
+ if (!variables)
83
+ return;
84
+ // for (const [key, value] of Object.entries(variables) as [string, any][]) {
85
+ // if (key.includes('dropdown-with-other')) {
86
+ // this.formObject = value;
87
+ // }
88
+ // }
89
+ for (const [key, value] of Object.entries(variables)) {
90
+ if (value &&
91
+ typeof value === 'object' &&
92
+ 'multipleChildSelectedOption' in value) {
93
+ this.multiChildDropdownMap.set(key, value);
94
+ }
95
+ }
96
+ });
97
+ const serviceUrl = this.fxApiService.getServiceUrl(this.setting('serviceMultiName'));
98
+ this.getOptions(serviceUrl, this.setting('multiChildOptionAPIURL'));
99
+ }
100
+ settings() {
101
+ return [
102
+ new FxOptionSetting({ key: 'itemsChildOption', $title: 'Options', value: [{ option: 'Yes', value: 'yes' }, { option: 'No', value: 'no' }] }, [{ option: 'Yes', value: 'yes' }, { option: 'No', value: 'no' }]),
103
+ new FxStringSetting({ key: 'multiChildOptionAPIURL', $title: 'API Url', value: '' }),
104
+ new FxStringSetting({ key: 'customClassMultiChild', $title: 'Custom Class Name', value: '' }),
105
+ new FxStringSetting({ key: 'select-label-multi-child', $title: 'Label', value: '' }),
106
+ new FxStringSetting({ key: 'label-key-child', $title: 'Label Key', value: 'option' }),
107
+ 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' }]),
108
+ new FxSelectSetting({ key: 'isMultiChildRequired', $title: 'Required', value: 'true' }, [{ option: 'Yes', value: 'true' }, { option: 'No', value: 'false' }]),
109
+ new FxStringSetting({ key: 'multiChildErrorMessage', $title: 'Error Message', value: 'Please select' }),
110
+ new FxStringSetting({ key: 'placeholderMultiChild', $title: 'Placeholder', value: 'Select' }),
111
+ new FxStringSetting({ key: 'child-1-label', $title: 'Child 1 Label', value: '' }),
112
+ new FxStringSetting({ key: 'child-1-placeholder', $title: 'Child 1 Placeholder', value: 'enter here' }),
113
+ new FxSelectSetting({ key: 'isChild1Required', $title: 'Required', value: 'true' }, [{ option: 'Yes', value: 'true' }, { option: 'No', value: 'false' }]),
114
+ new FxStringSetting({ key: 'child1ErrorMessage', $title: 'Error Message', value: 'Please fill out the field' }),
115
+ new FxStringSetting({ key: 'child-2-label', $title: 'Child 2 Label', value: '' }),
116
+ new FxStringSetting({ key: 'child-2-placeholder', $title: 'Child 2 Placeholder', value: 'enter here' }),
117
+ new FxSelectSetting({ key: 'isChild2Required', $title: 'Required', value: 'true' }, [{ option: 'Yes', value: 'true' }, { option: 'No', value: 'false' }]),
118
+ new FxStringSetting({ key: 'child2ErrorMessage', $title: 'Error Message', value: 'Please fill out the field' }),
119
+ ];
120
+ }
121
+ validations() {
122
+ return [];
123
+ }
124
+ getOptions(serviceUrl, url) {
125
+ if (url) {
126
+ const finalUrl = serviceUrl + url;
127
+ this.http.get(finalUrl).subscribe({
128
+ next: (response) => {
129
+ this.options = response?.data;
130
+ },
131
+ error: (err) => {
132
+ console.error('Error fetching options', err);
133
+ }
134
+ });
135
+ }
136
+ else {
137
+ this.options = this.fxComponent?.fxData?.settings?.find((s) => s.key === 'itemsChildOption')?.options || [];
138
+ }
139
+ }
140
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MultiselectDropdownWithChildsComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.HttpClient }, { token: i2.FxBuilderWrapperService }, { token: i3.ApiServiceRegistry }], target: i0.ɵɵFactoryTarget.Component });
141
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: MultiselectDropdownWithChildsComponent, isStandalone: true, selector: "lib-multiselect-dropdown-with-childs", viewQueries: [{ propertyName: "fxComponent", first: true, predicate: ["fxComponent"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<fx-component [fxData]=\"fxData\" #fxComponent>\r\n<div class=\"custom-dropdown\" [ngClass]=\"setting('customClassMultiChild')\">\r\n <form [formGroup]=\"multiChildDropDownForm\" 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-multi-child') }}\r\n </label>\r\n <p-multiSelect [options]=\"options\" formControlName=\"multipleChildSelectedOption\" [optionLabel]=\"setting('label-key-child')\"\r\n [placeholder]=\"setting('placeholderMultiChild')\" 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=\"multiChildDropDownForm.get('multipleChildSelectedOption')?.touched && multiChildDropDownForm.get('multipleChildSelectedOption')?.errors?.['required']\"\r\n class=\"text-red-500\">\r\n {{ setting('multiChildErrorMessage')}}\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('child-1-label') }}\r\n </label>\r\n <input\r\n type=\"text\"\r\n formControlName=\"child1\"\r\n placeholder=\"{{ setting('child-1-placeholder') }}\"\r\n class=\"border p-2 rounded w-full\"\r\n rows=\"2\"\r\n >\r\n\r\n <small\r\n *ngIf=\"multiChildDropDownForm.get('child1')?.touched && multiChildDropDownForm.get('child1')?.errors?.['required']\"\r\n class=\"text-red-500\"\r\n >\r\n {{ setting('child1ErrorMessage')}}\r\n </small>\r\n </div>\r\n\r\n <div class=\"flex-1\">\r\n <label class=\"input-label dark:text-gray-300\">\r\n {{ setting('child-2-label') }}\r\n </label>\r\n <input\r\n type=\"text\"\r\n formControlName=\"child2\"\r\n placeholder=\"{{ setting('child-2-placeholder') }}\"\r\n class=\"border p-2 rounded w-full\"\r\n rows=\"2\"\r\n >\r\n\r\n <small\r\n *ngIf=\"multiChildDropDownForm.get('child2')?.touched && multiChildDropDownForm.get('child2')?.errors?.['required']\"\r\n class=\"text-red-500\"\r\n >\r\n {{ setting('child2ErrorMessage')}}\r\n </small>\r\n </div>\r\n\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.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.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"] }] });
142
+ }
143
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MultiselectDropdownWithChildsComponent, decorators: [{
144
+ type: Component,
145
+ args: [{ selector: 'lib-multiselect-dropdown-with-childs', standalone: true, imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent, CalendarModule, MultiSelectModule], template: "<fx-component [fxData]=\"fxData\" #fxComponent>\r\n<div class=\"custom-dropdown\" [ngClass]=\"setting('customClassMultiChild')\">\r\n <form [formGroup]=\"multiChildDropDownForm\" 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-multi-child') }}\r\n </label>\r\n <p-multiSelect [options]=\"options\" formControlName=\"multipleChildSelectedOption\" [optionLabel]=\"setting('label-key-child')\"\r\n [placeholder]=\"setting('placeholderMultiChild')\" 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=\"multiChildDropDownForm.get('multipleChildSelectedOption')?.touched && multiChildDropDownForm.get('multipleChildSelectedOption')?.errors?.['required']\"\r\n class=\"text-red-500\">\r\n {{ setting('multiChildErrorMessage')}}\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('child-1-label') }}\r\n </label>\r\n <input\r\n type=\"text\"\r\n formControlName=\"child1\"\r\n placeholder=\"{{ setting('child-1-placeholder') }}\"\r\n class=\"border p-2 rounded w-full\"\r\n rows=\"2\"\r\n >\r\n\r\n <small\r\n *ngIf=\"multiChildDropDownForm.get('child1')?.touched && multiChildDropDownForm.get('child1')?.errors?.['required']\"\r\n class=\"text-red-500\"\r\n >\r\n {{ setting('child1ErrorMessage')}}\r\n </small>\r\n </div>\r\n\r\n <div class=\"flex-1\">\r\n <label class=\"input-label dark:text-gray-300\">\r\n {{ setting('child-2-label') }}\r\n </label>\r\n <input\r\n type=\"text\"\r\n formControlName=\"child2\"\r\n placeholder=\"{{ setting('child-2-placeholder') }}\"\r\n class=\"border p-2 rounded w-full\"\r\n rows=\"2\"\r\n >\r\n\r\n <small\r\n *ngIf=\"multiChildDropDownForm.get('child2')?.touched && multiChildDropDownForm.get('child2')?.errors?.['required']\"\r\n class=\"text-red-500\"\r\n >\r\n {{ setting('child2ErrorMessage')}}\r\n </small>\r\n </div>\r\n\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"] }]
146
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.HttpClient }, { type: i2.FxBuilderWrapperService }, { type: i3.ApiServiceRegistry }], propDecorators: { fxComponent: [{
147
+ type: ViewChild,
148
+ args: ['fxComponent']
149
+ }] } });
150
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multiselect-dropdown-with-childs.component.js","sourceRoot":"","sources":["../../../../../../projects/fx-builder-wrapper/src/lib/components/multiselect-dropdown-with-childs/multiselect-dropdown-with-childs.component.ts","../../../../../../projects/fx-builder-wrapper/src/lib/components/multiselect-dropdown-with-childs/multiselect-dropdown-with-childs.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-with-childs',\r\n  standalone: true,\r\n  imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent, CalendarModule, MultiSelectModule],\r\n  templateUrl: './multiselect-dropdown-with-childs.component.html',\r\n  styleUrl: './multiselect-dropdown-with-childs.component.css'\r\n})\r\nexport class MultiselectDropdownWithChildsComponent extends FxBaseComponent implements OnInit, AfterViewInit{\r\n   private fb = inject(FormBuilder);\r\n  private destroy$ = new Subject<Boolean>();\r\n  formObject: object = {};\r\n  multiChildDropdownMap = new Map<string, any>();\r\n  @ViewChild('fxComponent') fxComponent!: FxComponent;\r\n \r\n  options: any[] = [];\r\n\r\n  public multiChildDropDownForm: FormGroup = this.fb.group({\r\n    multipleChildSelectedOption: [[]],\r\n    child1: [''],\r\n    child2: [''],\r\n    child1Label: [''],\r\n    child2Label: [''],\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.multiChildDropDownForm);\r\n    });\r\n\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n\r\n    if (!this.setting('multiChildOptionAPIURL')) {\r\n      this.options = (this.fxComponent?.fxData?.settings?.find((s: any) => s.key === 'itemsChildOption') as any)?.options || [];\r\n    }\r\n\r\n     const child1LabelControl = this.multiChildDropDownForm.get('child1Label');\r\n     const child2LabelControl = this.multiChildDropDownForm.get('child2Label');\r\n      child1LabelControl?.setValue(this.setting('child-1-label'));  \r\n      child2LabelControl?.setValue(this.setting('child-2-label'));\r\n      child1LabelControl?.updateValueAndValidity();\r\n      child2LabelControl?.updateValueAndValidity(); \r\n\r\n\r\n    setTimeout(() => {\r\n      const key = this.fxComponent?.fxData?.name;\r\n\r\n      if (key && this.multiChildDropdownMap.has(key)) {\r\n        this.multiChildDropDownForm.patchValue(this.multiChildDropdownMap.get(key));\r\n      }\r\n    }, 200);\r\n\r\n    setTimeout(() => {\r\n      const mainControl = this.multiChildDropDownForm.get('multipleChildSelectedOption');\r\n      const child1Control = this.multiChildDropDownForm.get('child1');\r\n      const child2Control = this.multiChildDropDownForm.get('child2');\r\n      if (this.setting('isMultiChildRequired') === 'true') {\r\n        mainControl?.setValidators([Validators.required]);\r\n        mainControl?.updateValueAndValidity();\r\n      }\r\n      if (this.setting('isChild1Required') === 'true') {\r\n        child1Control?.setValidators([Validators.required]);\r\n        child1Control?.updateValueAndValidity();\r\n      }\r\n      if (this.setting('isChild2Required') === 'true') {\r\n        child2Control?.setValidators([Validators.required]);\r\n        child2Control?.updateValueAndValidity();\r\n      }\r\n    }, 1000)\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            'multipleChildSelectedOption' in value\r\n          ) {\r\n            this.multiChildDropdownMap.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('multiChildOptionAPIURL'));\r\n  }\r\n\r\n  protected settings(): FxSetting[] {\r\n    return [\r\n      new FxOptionSetting({ key: 'itemsChildOption', $title: 'Options', value: [{ option: 'Yes', value: 'yes' }, { option: 'No', value: 'no' }] }, [{ option: 'Yes', value: 'yes' }, { option: 'No', value: 'no' }]),\r\n      new FxStringSetting({ key: 'multiChildOptionAPIURL', $title: 'API Url', value: '' }),\r\n      new FxStringSetting({ key: 'customClassMultiChild', $title: 'Custom Class Name', value: '' }),\r\n      new FxStringSetting({ key: 'select-label-multi-child', $title: 'Label', value: '' }),\r\n      new FxStringSetting({ key: 'label-key-child', $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: 'isMultiChildRequired', $title: 'Required', value: 'true' }, [{ option: 'Yes', value: 'true' }, { option: 'No', value: 'false' }]),\r\n      new FxStringSetting({ key: 'multiChildErrorMessage', $title: 'Error Message', value: 'Please select' }),\r\n      new FxStringSetting({ key: 'placeholderMultiChild', $title: 'Placeholder', value: 'Select' }),\r\n\r\n       new FxStringSetting({ key: 'child-1-label', $title: 'Child 1 Label', value: '' }),\r\n       new FxStringSetting({ key: 'child-1-placeholder', $title: 'Child 1 Placeholder', value: 'enter here' }),\r\n       new FxSelectSetting({ key: 'isChild1Required', $title: 'Required', value: 'true' }, [{ option: 'Yes', value: 'true' }, { option: 'No', value: 'false' }]),\r\n       new FxStringSetting({ key: 'child1ErrorMessage', $title: 'Error Message', value: 'Please fill out the field' }),\r\n\r\n        new FxStringSetting({ key: 'child-2-label', $title: 'Child 2 Label', value: '' }),\r\n        new FxStringSetting({ key: 'child-2-placeholder', $title: 'Child 2 Placeholder', value: 'enter here' }),\r\n        new FxSelectSetting({ key: 'isChild2Required', $title: 'Required', value: 'true' }, [{ option: 'Yes', value: 'true' }, { option: 'No', value: 'false' }]),\r\n        new FxStringSetting({ key: 'child2ErrorMessage', $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  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 === 'itemsChildOption') as any)?.options || [];\r\n    }\r\n  }\r\n\r\n}\r\n","<fx-component [fxData]=\"fxData\" #fxComponent>\r\n<div class=\"custom-dropdown\" [ngClass]=\"setting('customClassMultiChild')\">\r\n  <form [formGroup]=\"multiChildDropDownForm\" 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-multi-child') }}\r\n        </label>\r\n        <p-multiSelect [options]=\"options\" formControlName=\"multipleChildSelectedOption\" [optionLabel]=\"setting('label-key-child')\"\r\n          [placeholder]=\"setting('placeholderMultiChild')\" 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=\"multiChildDropDownForm.get('multipleChildSelectedOption')?.touched && multiChildDropDownForm.get('multipleChildSelectedOption')?.errors?.['required']\"\r\n          class=\"text-red-500\">\r\n          {{ setting('multiChildErrorMessage')}}\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('child-1-label') }}\r\n      </label>\r\n      <input\r\n        type=\"text\"\r\n        formControlName=\"child1\"\r\n        placeholder=\"{{ setting('child-1-placeholder') }}\"\r\n        class=\"border p-2 rounded w-full\"\r\n        rows=\"2\"\r\n      >\r\n\r\n      <small\r\n        *ngIf=\"multiChildDropDownForm.get('child1')?.touched && multiChildDropDownForm.get('child1')?.errors?.['required']\"\r\n        class=\"text-red-500\"\r\n      >\r\n        {{ setting('child1ErrorMessage')}}\r\n      </small>\r\n    </div>\r\n\r\n    <div class=\"flex-1\">\r\n      <label class=\"input-label dark:text-gray-300\">\r\n        {{ setting('child-2-label') }}\r\n      </label>\r\n      <input\r\n        type=\"text\"\r\n        formControlName=\"child2\"\r\n        placeholder=\"{{ setting('child-2-placeholder') }}\"\r\n        class=\"border p-2 rounded w-full\"\r\n        rows=\"2\"\r\n      >\r\n\r\n      <small\r\n        *ngIf=\"multiChildDropDownForm.get('child2')?.touched && multiChildDropDownForm.get('child2')?.errors?.['required']\"\r\n        class=\"text-red-500\"\r\n      >\r\n        {{ setting('child2ErrorMessage')}}\r\n      </small>\r\n    </div>\r\n\r\n  </form>\r\n</div>\r\n</fx-component>"]}