fx-form-builder-wrapper 2.0.80 → 2.0.82
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/dropdown-with-other/dropdown-with-other.component.mjs +5 -8
- package/esm2022/lib/components/dropdown-with-search/dropdown-with-search.component.mjs +124 -0
- package/esm2022/lib/components/fx-form-component/fx-form-component.component.mjs +7 -1
- package/esm2022/lib/components/multiselect-dropdown/multiselect-dropdown.component.mjs +3 -3
- package/esm2022/lib/components/multiselect-dropdown-with-childs/multiselect-dropdown-with-childs.component.mjs +150 -0
- package/esm2022/lib/components/multiselect-with-form-fields/customize-dropdown.component.mjs +225 -0
- package/esm2022/lib/components/multiselect-with-form-fields/multiselect-dropdown.component.mjs +166 -0
- package/esm2022/lib/fx-builder-wrapper.component.mjs +13 -1
- package/fesm2022/fx-form-builder-wrapper.mjs +480 -13
- package/fesm2022/fx-form-builder-wrapper.mjs.map +1 -1
- package/lib/components/dropdown-with-search/dropdown-with-search.component.d.ts +28 -0
- package/lib/components/multiselect-dropdown-with-childs/multiselect-dropdown-with-childs.component.d.ts +28 -0
- package/lib/components/multiselect-with-form-fields/customize-dropdown.component.d.ts +59 -0
- package/lib/components/multiselect-with-form-fields/multiselect-dropdown.component.d.ts +51 -0
- package/package.json +1 -1
|
@@ -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
|
|
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 relative\">\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
|
|
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 relative\">\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":"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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  <div class=\"custom-dropdown\" [ngClass]=\"setting('customClassMulti')\">\r\n    <form [formGroup]=\"multiselectDropDownForm\" class=\"flex gap-4 w-full\">\r\n      <div class=\"flex-1 relative\">\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 relative\">\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 relative\">\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 relative\">\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 relative\">\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 relative\">\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 relative\">\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 relative\">\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 relative\">\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 relative\">\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>"]}
|