fx-form-builder-wrapper 2.0.2 → 2.0.4
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/date-picker/date-picker.component.mjs +41 -10
- package/esm2022/lib/components/fx-form-component/fx-form-component.component.mjs +4 -2
- package/esm2022/lib/fx-builder-wrapper.service.mjs +7 -2
- package/fesm2022/fx-form-builder-wrapper.mjs +43 -8
- package/fesm2022/fx-form-builder-wrapper.mjs.map +1 -1
- package/lib/components/date-picker/date-picker.component.d.ts +8 -2
- package/lib/fx-builder-wrapper.service.d.ts +2 -0
- package/package.json +1 -1
|
@@ -1,31 +1,52 @@
|
|
|
1
1
|
import { CommonModule } from '@angular/common';
|
|
2
|
-
import { Component, inject } from '@angular/core';
|
|
2
|
+
import { Component, inject, ViewChild } from '@angular/core';
|
|
3
3
|
import { ReactiveFormsModule, FormsModule, FormBuilder, Validators } from '@angular/forms';
|
|
4
4
|
import { FxBaseComponent, FxComponent, FxStringSetting, FxValidatorService } from '@instantsys-labs/fx';
|
|
5
5
|
import { CalendarModule } from 'primeng/calendar';
|
|
6
|
+
import { Subject, takeUntil } from 'rxjs';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
import * as i1 from "@angular/common/http";
|
|
8
|
-
import * as i2 from "
|
|
9
|
-
import * as i3 from "@angular/
|
|
10
|
-
import * as i4 from "
|
|
9
|
+
import * as i2 from "../../fx-builder-wrapper.service";
|
|
10
|
+
import * as i3 from "@angular/common";
|
|
11
|
+
import * as i4 from "@angular/forms";
|
|
12
|
+
import * as i5 from "primeng/calendar";
|
|
11
13
|
export class DatePickerComponent extends FxBaseComponent {
|
|
12
14
|
cdr;
|
|
13
15
|
http;
|
|
16
|
+
fxBuilderWrapperService;
|
|
14
17
|
fb = inject(FormBuilder);
|
|
15
18
|
minDate = new Date();
|
|
16
19
|
maxDate = new Date();
|
|
20
|
+
fxComponent;
|
|
21
|
+
destroy$ = new Subject();
|
|
22
|
+
datePickerMap = new Map();
|
|
17
23
|
datePickerForm = this.fb.group({
|
|
18
24
|
date: ['', Validators.required],
|
|
19
25
|
});
|
|
20
|
-
constructor(cdr, http) {
|
|
26
|
+
constructor(cdr, http, fxBuilderWrapperService) {
|
|
21
27
|
super(cdr);
|
|
22
28
|
this.cdr = cdr;
|
|
23
29
|
this.http = http;
|
|
30
|
+
this.fxBuilderWrapperService = fxBuilderWrapperService;
|
|
24
31
|
this.onInit.subscribe(() => {
|
|
25
32
|
this._register(this.datePickerForm);
|
|
26
33
|
});
|
|
27
34
|
}
|
|
28
35
|
ngOnInit() {
|
|
36
|
+
this.fxBuilderWrapperService.variables$
|
|
37
|
+
.pipe(takeUntil(this.destroy$))
|
|
38
|
+
.subscribe((variables) => {
|
|
39
|
+
if (!variables)
|
|
40
|
+
return;
|
|
41
|
+
this.datePickerMap = new Map();
|
|
42
|
+
for (const [key, value] of Object.entries(variables)) {
|
|
43
|
+
if (key.includes('lib-date-picker')) {
|
|
44
|
+
this.datePickerMap.set(key, value);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
// You can now use datePickerMap as needed
|
|
48
|
+
console.log('Date Picker Variables:', this.datePickerMap);
|
|
49
|
+
});
|
|
29
50
|
const today = new Date();
|
|
30
51
|
this.minDate = new Date(today);
|
|
31
52
|
this.minDate.setDate(today.getDate() - 30);
|
|
@@ -36,6 +57,13 @@ export class DatePickerComponent extends FxBaseComponent {
|
|
|
36
57
|
get dateControl() {
|
|
37
58
|
return this.datePickerForm.get('date');
|
|
38
59
|
}
|
|
60
|
+
ngAfterViewInit() {
|
|
61
|
+
const key = this.fxComponent?.fxData?.name;
|
|
62
|
+
if (key) {
|
|
63
|
+
this.datePickerForm.patchValue({ date: this.datePickerMap.get(key) });
|
|
64
|
+
}
|
|
65
|
+
this.getContextBaseId();
|
|
66
|
+
}
|
|
39
67
|
getRangeValues() {
|
|
40
68
|
this.http.get(this.setting('apiURL')).subscribe(response => {
|
|
41
69
|
const today = new Date();
|
|
@@ -59,11 +87,14 @@ export class DatePickerComponent extends FxBaseComponent {
|
|
|
59
87
|
validations() {
|
|
60
88
|
return [FxValidatorService.required];
|
|
61
89
|
}
|
|
62
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DatePickerComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.HttpClient }], target: i0.ɵɵFactoryTarget.Component });
|
|
63
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DatePickerComponent, isStandalone: true, selector: "lib-date-picker", usesInheritance: true, ngImport: i0, template: "<fx-component [fxData]=\"fxData\">\r\n <div class=\"
|
|
90
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DatePickerComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.HttpClient }, { token: i2.FxBuilderWrapperService }], target: i0.ɵɵFactoryTarget.Component });
|
|
91
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DatePickerComponent, isStandalone: true, selector: "lib-date-picker", viewQueries: [{ propertyName: "fxComponent", first: true, predicate: ["fxComponent"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<fx-component [fxData]=\"fxData\" #fxComponent>\r\n <div class=\"flex justify-content-center\">\r\n <form [formGroup]=\"datePickerForm\" class=\"flex flex-column gap-2\">\r\n <p-calendar \r\n formControlName=\"date\" \r\n [showIcon]=\"true\"\r\n [minDate]=\"minDate\"\r\n [maxDate]=\"maxDate\"\r\n dateFormat=\"dd/mm/yy\"\r\n [showButtonBar]=\"true\"\r\n ></p-calendar>\r\n \r\n <small *ngIf=\"datePickerForm.get('date')?.touched && datePickerForm.get('date')?.errors?.['required']\" class=\"text-red-500\">\r\n Date is required.\r\n </small>\r\n </form>\r\n </div>\r\n \r\n</fx-component>\r\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.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: "component", type: i5.Calendar, selector: "p-calendar", inputs: ["iconDisplay", "style", "styleClass", "inputStyle", "inputId", "name", "inputStyleClass", "placeholder", "ariaLabelledBy", "ariaLabel", "iconAriaLabel", "disabled", "dateFormat", "multipleSeparator", "rangeSeparator", "inline", "showOtherMonths", "selectOtherMonths", "showIcon", "icon", "appendTo", "readonlyInput", "shortYearCutoff", "monthNavigator", "yearNavigator", "hourFormat", "timeOnly", "stepYearPicker", "stepHour", "stepMinute", "stepSecond", "showSeconds", "required", "showOnFocus", "showWeek", "startWeekFromFirstDayOfYear", "showClear", "dataType", "selectionMode", "maxDateCount", "showButtonBar", "todayButtonStyleClass", "clearButtonStyleClass", "autofocus", "autoZIndex", "baseZIndex", "panelStyleClass", "panelStyle", "keepInvalid", "hideOnDateTimeSelect", "touchUI", "timeSeparator", "focusTrap", "showTransitionOptions", "hideTransitionOptions", "tabindex", "variant", "minDate", "maxDate", "disabledDates", "disabledDays", "yearRange", "showTime", "responsiveOptions", "numberOfMonths", "firstDayOfWeek", "locale", "view", "defaultDate"], outputs: ["onFocus", "onBlur", "onClose", "onSelect", "onClear", "onInput", "onTodayClick", "onClearClick", "onMonthChange", "onYearChange", "onClickOutside", "onShow"] }] });
|
|
64
92
|
}
|
|
65
93
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DatePickerComponent, decorators: [{
|
|
66
94
|
type: Component,
|
|
67
|
-
args: [{ selector: 'lib-date-picker', standalone: true, imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent, CalendarModule], template: "<fx-component [fxData]=\"fxData\">\r\n <div class=\"
|
|
68
|
-
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.HttpClient }]
|
|
69
|
-
|
|
95
|
+
args: [{ selector: 'lib-date-picker', standalone: true, imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent, CalendarModule], template: "<fx-component [fxData]=\"fxData\" #fxComponent>\r\n <div class=\"flex justify-content-center\">\r\n <form [formGroup]=\"datePickerForm\" class=\"flex flex-column gap-2\">\r\n <p-calendar \r\n formControlName=\"date\" \r\n [showIcon]=\"true\"\r\n [minDate]=\"minDate\"\r\n [maxDate]=\"maxDate\"\r\n dateFormat=\"dd/mm/yy\"\r\n [showButtonBar]=\"true\"\r\n ></p-calendar>\r\n \r\n <small *ngIf=\"datePickerForm.get('date')?.touched && datePickerForm.get('date')?.errors?.['required']\" class=\"text-red-500\">\r\n Date is required.\r\n </small>\r\n </form>\r\n </div>\r\n \r\n</fx-component>\r\n" }]
|
|
96
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.HttpClient }, { type: i2.FxBuilderWrapperService }], propDecorators: { fxComponent: [{
|
|
97
|
+
type: ViewChild,
|
|
98
|
+
args: ['fxComponent']
|
|
99
|
+
}] } });
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/fx-builder-wrapper/src/lib/components/date-picker/date-picker.component.ts","../../../../../../projects/fx-builder-wrapper/src/lib/components/date-picker/date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { ChangeDetectorRef, Component, inject, OnInit, ViewChild } from '@angular/core';\r\nimport { ReactiveFormsModule, FormsModule, FormBuilder, FormGroup, Validators } from '@angular/forms';\r\nimport { FxBaseComponent, FxComponent, FxSetting, FxStringSetting, FxValidation, FxValidatorService } from '@instantsys-labs/fx';\r\nimport { CalendarModule } from 'primeng/calendar';\r\nimport { FxBuilderWrapperService } from '../../fx-builder-wrapper.service';\r\nimport { Subject, takeUntil } from 'rxjs';\r\n@Component({\r\n  selector: 'lib-date-picker',\r\n  standalone: true,\r\n imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent, CalendarModule],\r\n  templateUrl: './date-picker.component.html',\r\n  styleUrl: './date-picker.component.css'\r\n})\r\nexport class DatePickerComponent extends FxBaseComponent implements OnInit{\r\n   private fb = inject(FormBuilder);\r\n   minDate: Date = new Date();\r\n   maxDate: Date = new Date();\r\n   @ViewChild('fxComponent') fxComponent!: FxComponent;\r\n   private destroy$ = new Subject<Boolean>();\r\n    datePickerMap = new Map<string, any>();\r\n   \r\n\r\n\r\n    public datePickerForm: FormGroup = this.fb.group({\r\n       date: ['', Validators.required],\r\n     })\r\n\r\n   constructor(private cdr: ChangeDetectorRef,private http: HttpClient,private fxBuilderWrapperService: FxBuilderWrapperService) {\r\n      super(cdr)\r\n      this.onInit.subscribe(() => {\r\n        this._register(this.datePickerForm);\r\n      });\r\n     \r\n    }\r\n\r\n\r\n  ngOnInit(): void {\r\n\r\n   this.fxBuilderWrapperService.variables$\r\n  .pipe(takeUntil(this.destroy$))\r\n  .subscribe((variables: any) => {\r\n    if (!variables) return;\r\n\r\n    this.datePickerMap = new Map<string, any>();\r\n\r\n    for (const [key, value] of Object.entries(variables) as [string, any][]) {\r\n      if (key.includes('lib-date-picker')) {\r\n        this.datePickerMap.set(key, value);\r\n      }\r\n    }\r\n\r\n    // You can now use datePickerMap as needed\r\n    console.log('Date Picker Variables:', this.datePickerMap);\r\n  });\r\n\r\n\r\n    const today = new Date();\r\n    this.minDate = new Date(today);\r\n    this.minDate.setDate(today.getDate() - 30);\r\n\r\n    this.maxDate = new Date(today);\r\n    this.maxDate.setDate(today.getDate() + 30);\r\n    this.getRangeValues();\r\n\r\n  }\r\n\r\n  get dateControl() {\r\n    return this.datePickerForm.get('date');\r\n  }\r\n\r\n   ngAfterViewInit(): void {\r\n    const key = this.fxComponent?.fxData?.name;\r\n    if(key){\r\n      this.datePickerForm.patchValue({date:this.datePickerMap.get(key)});\r\n    }\r\n    this.getContextBaseId();\r\n  }\r\n\r\n  getRangeValues() {\r\n    this.http.get<any>(this.setting('apiURL')).subscribe(response => {\r\n      const today = new Date();\r\n  \r\n      const minOffset = response[this.setting('minDateKey')] || this.setting('minValidation');\r\n      const maxOffset = response[this.setting('maxDateKey')] || this.setting('maxValidation');\r\n  \r\n      this.minDate = new Date(today);\r\n      this.minDate.setDate(today.getDate() + minOffset);\r\n  \r\n      this.maxDate = new Date(today);\r\n      this.maxDate.setDate(today.getDate() + maxOffset);\r\n    });\r\n  }\r\n  \r\n\r\n\r\n    protected settings(): FxSetting[] {\r\n        return [\r\n          new FxStringSetting({ key: 'minValidation', $title: 'Min Validation', value: '' }),\r\n          new FxStringSetting({ key: 'maxValidation', $title: 'Max Validation', value: '' }),\r\n          new FxStringSetting({ key: 'apiURL', $title: 'API Url', value: '' }),\r\n          new FxStringSetting({ key: 'minDateKey', $title: 'Min Range API Key', value: '' }),\r\n          new FxStringSetting({ key: 'maxDateKey', $title: 'Max Range API Key', value: '' }),\r\n         \r\n        ];\r\n      }\r\n    \r\n      protected validations(): FxValidation[] {\r\n        return [FxValidatorService.required];\r\n      }\r\n}\r\n","<fx-component [fxData]=\"fxData\" #fxComponent>\r\n    <div class=\"flex justify-content-center\">\r\n        <form [formGroup]=\"datePickerForm\" class=\"flex flex-column gap-2\">\r\n          <p-calendar \r\n            formControlName=\"date\" \r\n            [showIcon]=\"true\"\r\n            [minDate]=\"minDate\"\r\n            [maxDate]=\"maxDate\"\r\n            dateFormat=\"dd/mm/yy\"\r\n            [showButtonBar]=\"true\"\r\n          ></p-calendar>\r\n      \r\n          <small *ngIf=\"datePickerForm.get('date')?.touched && datePickerForm.get('date')?.errors?.['required']\" class=\"text-red-500\">\r\n            Date is required.\r\n          </small>\r\n        </form>\r\n      </div>\r\n      \r\n</fx-component>\r\n"]}
|
|
@@ -7,6 +7,7 @@ import { ToggleButtonComponent } from '../toggle-button/toggle-button.component'
|
|
|
7
7
|
import { UploaderComponent } from '../uploader/uploader.component';
|
|
8
8
|
import { ToggleComponent } from '../toggle/toggle.component';
|
|
9
9
|
import { UploaderCheckboxComponent } from '../uploader-checkbox/uploader-checkbox.component';
|
|
10
|
+
import { DatePickerComponent } from '../date-picker/date-picker.component';
|
|
10
11
|
import * as i0 from "@angular/core";
|
|
11
12
|
import * as i1 from "../../fx-builder-wrapper.service";
|
|
12
13
|
export class FxFormWrapperComponent {
|
|
@@ -51,7 +52,8 @@ export class FxFormWrapperComponent {
|
|
|
51
52
|
{ name: 'Toggle Button', key: 'toggle-button', component: ToggleButtonComponent },
|
|
52
53
|
{ name: 'Uploader', key: 'uploader', component: UploaderComponent },
|
|
53
54
|
{ name: 'Toggle', key: 'toggle', component: ToggleComponent },
|
|
54
|
-
{ name: 'Uploader with Checkbox', key: 'uploader-checkbox', component: UploaderCheckboxComponent }
|
|
55
|
+
{ name: 'Uploader with Checkbox', key: 'uploader-checkbox', component: UploaderCheckboxComponent },
|
|
56
|
+
{ name: 'Date Picker', key: 'lib-date-picker', component: DatePickerComponent }
|
|
55
57
|
];
|
|
56
58
|
components.forEach(({ name, key, component }) => {
|
|
57
59
|
if (!this.fxWrapperService.getComponent(key)) {
|
|
@@ -102,4 +104,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
102
104
|
}], fxFormSubmit: [{
|
|
103
105
|
type: Output
|
|
104
106
|
}] } });
|
|
105
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
107
|
+
//# 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\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    ];\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"]}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
1
|
+
import { inject, Injectable } from '@angular/core';
|
|
2
|
+
import { ApiServiceRegistry } from '@instantsys-labs/core';
|
|
2
3
|
import { FxUtils } from '@instantsys-labs/fx';
|
|
3
4
|
import { BehaviorSubject } from 'rxjs';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
@@ -6,6 +7,7 @@ import * as i1 from "@instantsys-labs/fx";
|
|
|
6
7
|
export class FxBuilderWrapperService {
|
|
7
8
|
fxComponentRegistry;
|
|
8
9
|
variables$ = new BehaviorSubject(null);
|
|
10
|
+
fxApiRegistryService = inject(ApiServiceRegistry);
|
|
9
11
|
constructor(fxComponentRegistry) {
|
|
10
12
|
this.fxComponentRegistry = fxComponentRegistry;
|
|
11
13
|
}
|
|
@@ -32,6 +34,9 @@ export class FxBuilderWrapperService {
|
|
|
32
34
|
getInitializedFxForm() {
|
|
33
35
|
return FxUtils.createNewForm();
|
|
34
36
|
}
|
|
37
|
+
setService(object) {
|
|
38
|
+
this.fxApiRegistryService.registerService(object);
|
|
39
|
+
}
|
|
35
40
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FxBuilderWrapperService, deps: [{ token: i1.FxComponentRegistryService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
36
41
|
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FxBuilderWrapperService, providedIn: 'root' });
|
|
37
42
|
}
|
|
@@ -41,4 +46,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
41
46
|
providedIn: 'root'
|
|
42
47
|
}]
|
|
43
48
|
}], ctorParameters: () => [{ type: i1.FxComponentRegistryService }] });
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZngtYnVpbGRlci13cmFwcGVyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9meC1idWlsZGVyLXdyYXBwZXIvc3JjL2xpYi9meC1idWlsZGVyLXdyYXBwZXIuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBUSxNQUFNLGVBQWUsQ0FBQztBQUN6RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUMzRCxPQUFPLEVBQXVELE9BQU8sRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ25HLE9BQU8sRUFBRSxlQUFlLEVBQVcsTUFBTSxNQUFNLENBQUM7OztBQUtoRCxNQUFNLE9BQU8sdUJBQXVCO0lBR2Q7SUFGYixVQUFVLEdBQUcsSUFBSSxlQUFlLENBQWEsSUFBSSxDQUFDLENBQUM7SUFDakQsb0JBQW9CLEdBQUcsTUFBTSxDQUFDLGtCQUFrQixDQUFDLENBQUE7SUFDMUQsWUFBb0IsbUJBQStDO1FBQS9DLHdCQUFtQixHQUFuQixtQkFBbUIsQ0FBNEI7SUFBSSxDQUFDO0lBRWpFLHVCQUF1QixDQUFDLEtBQWEsRUFBRSxRQUFnQixFQUFFLFNBQWdDO1FBRTlGLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxpQkFBaUIsQ0FBQyxRQUFRLEVBQUUsU0FBUyxFQUFFO1lBQzlELGFBQWEsRUFBRSxRQUFRO1lBQ3ZCLFdBQVcsRUFBRTtnQkFDWCxLQUFLO2dCQUNMLElBQUksRUFBRSxRQUFRO2dCQUNkLE1BQU0sRUFBRTtvQkFDTixFQUFFLEVBQUUsSUFBSTtvQkFDUixJQUFJLEVBQUUsUUFBUTtvQkFDZCxLQUFLLEVBQUUsRUFBRTtvQkFDVCxRQUFRLEVBQUUsUUFBUTtvQkFDbEIsUUFBUSxFQUFFLEVBQUU7b0JBQ1osTUFBTSxFQUFFLEVBQUU7aUJBQ1g7YUFDRjtTQUNGLENBQUMsQ0FBQTtJQUNKLENBQUM7SUFFTSxZQUFZLENBQUMsUUFBZ0I7UUFDbEMsT0FBTyxJQUFJLENBQUMsbUJBQW1CLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ3pELENBQUM7SUFFTyxvQkFBb0I7UUFDeEIsT0FBTyxPQUFPLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDakMsQ0FBQztJQUVNLFVBQVUsQ0FBQyxNQUFVO1FBQzFCLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxlQUFlLENBQUMsTUFBTSxDQUFDLENBQUE7SUFDbkQsQ0FBQzt3R0FsQ1EsdUJBQXVCOzRHQUF2Qix1QkFBdUIsY0FGdEIsTUFBTTs7NEZBRVAsdUJBQXVCO2tCQUhuQyxVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGluamVjdCwgSW5qZWN0YWJsZSwgVHlwZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBcGlTZXJ2aWNlUmVnaXN0cnkgfSBmcm9tICdAaW5zdGFudHN5cy1sYWJzL2NvcmUnO1xyXG5pbXBvcnQgeyBGeEJhc2VDb21wb25lbnQsIEZ4Q29tcG9uZW50UmVnaXN0cnlTZXJ2aWNlLCBGeEZvcm0sIEZ4VXRpbHMgfSBmcm9tICdAaW5zdGFudHN5cy1sYWJzL2Z4JztcclxuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0LCBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBGeEJ1aWxkZXJXcmFwcGVyU2VydmljZSB7XHJcbiAgcHVibGljIHZhcmlhYmxlcyQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PGFueSB8IG51bGw+KG51bGwpO1xyXG4gICBwcml2YXRlIGZ4QXBpUmVnaXN0cnlTZXJ2aWNlID0gaW5qZWN0KEFwaVNlcnZpY2VSZWdpc3RyeSlcclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGZ4Q29tcG9uZW50UmVnaXN0cnk6IEZ4Q29tcG9uZW50UmVnaXN0cnlTZXJ2aWNlKSB7IH1cclxuXHJcbiAgcHVibGljIHJlZ2lzdGVyQ3VzdG9tQ29tcG9uZW50KHRpdGxlOiBzdHJpbmcsIHNlbGVjdG9yOiBzdHJpbmcsIGNvbXBvbmVudDogVHlwZTxGeEJhc2VDb21wb25lbnQ+XHJcbiAgKTogdm9pZCB7XHJcbiAgICB0aGlzLmZ4Q29tcG9uZW50UmVnaXN0cnkucmVnaXN0ZXJDb21wb25lbnQoc2VsZWN0b3IsIGNvbXBvbmVudCwge1xyXG4gICAgICByZWdpc3RlcmluZ0FzOiBcIkNVU1RPTVwiLFxyXG4gICAgICBsaWJyYXJ5SXRlbToge1xyXG4gICAgICAgIHRpdGxlLFxyXG4gICAgICAgIGljb246ICdmYS1leWUnLFxyXG4gICAgICAgIGZ4RGF0YToge1xyXG4gICAgICAgICAgaWQ6IG51bGwsXHJcbiAgICAgICAgICBuYW1lOiBzZWxlY3RvcixcclxuICAgICAgICAgIHZhbHVlOiBcIlwiLFxyXG4gICAgICAgICAgc2VsZWN0b3I6IHNlbGVjdG9yLFxyXG4gICAgICAgICAgZWxlbWVudHM6IFtdLFxyXG4gICAgICAgICAgZXZlbnRzOiBbXVxyXG4gICAgICAgIH1cclxuICAgICAgfSxcclxuICAgIH0pXHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0Q29tcG9uZW50KHNlbGVjdG9yOiBzdHJpbmcpOiBUeXBlPEZ4QmFzZUNvbXBvbmVudD4gfCB1bmRlZmluZWQge1xyXG4gICAgcmV0dXJuIHRoaXMuZnhDb21wb25lbnRSZWdpc3RyeS5nZXRDb21wb25lbnQoc2VsZWN0b3IpO1xyXG4gIH1cclxuXHJcbiAgIHB1YmxpYyBnZXRJbml0aWFsaXplZEZ4Rm9ybSgpOiBGeEZvcm0ge1xyXG4gICAgICByZXR1cm4gRnhVdGlscy5jcmVhdGVOZXdGb3JtKCk7IFxyXG4gICAgfVxyXG5cclxuICAgIHB1YmxpYyBzZXRTZXJ2aWNlKG9iamVjdDphbnkpe1xyXG4gICAgICB0aGlzLmZ4QXBpUmVnaXN0cnlTZXJ2aWNlLnJlZ2lzdGVyU2VydmljZShvYmplY3QpXHJcbiAgICB9XHJcbn1cclxuIl19
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { inject, Injectable, Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
3
|
+
import { ApiServiceRegistry } from '@instantsys-labs/core';
|
|
3
4
|
import * as i1 from '@instantsys-labs/fx';
|
|
4
5
|
import { FxUtils, FxBaseComponent, FxStringSetting, FxValidatorService, FxComponent, FxMode, FxSelectSetting, FxScope, FxComponentBuilder, FxFormComponent } from '@instantsys-labs/fx';
|
|
5
6
|
import { BehaviorSubject, Subject, takeUntil, map, forkJoin } from 'rxjs';
|
|
@@ -25,12 +26,13 @@ import { ToastModule } from 'primeng/toast';
|
|
|
25
26
|
import * as i7 from 'primeng/confirmdialog';
|
|
26
27
|
import { ConfirmDialogModule } from 'primeng/confirmdialog';
|
|
27
28
|
import { v4 } from 'uuid';
|
|
28
|
-
import * as
|
|
29
|
+
import * as i5$2 from 'primeng/calendar';
|
|
29
30
|
import { CalendarModule } from 'primeng/calendar';
|
|
30
31
|
|
|
31
32
|
class FxBuilderWrapperService {
|
|
32
33
|
fxComponentRegistry;
|
|
33
34
|
variables$ = new BehaviorSubject(null);
|
|
35
|
+
fxApiRegistryService = inject(ApiServiceRegistry);
|
|
34
36
|
constructor(fxComponentRegistry) {
|
|
35
37
|
this.fxComponentRegistry = fxComponentRegistry;
|
|
36
38
|
}
|
|
@@ -57,6 +59,9 @@ class FxBuilderWrapperService {
|
|
|
57
59
|
getInitializedFxForm() {
|
|
58
60
|
return FxUtils.createNewForm();
|
|
59
61
|
}
|
|
62
|
+
setService(object) {
|
|
63
|
+
this.fxApiRegistryService.registerService(object);
|
|
64
|
+
}
|
|
60
65
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FxBuilderWrapperService, deps: [{ token: i1.FxComponentRegistryService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
61
66
|
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FxBuilderWrapperService, providedIn: 'root' });
|
|
62
67
|
}
|
|
@@ -1617,21 +1622,40 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
1617
1622
|
class DatePickerComponent extends FxBaseComponent {
|
|
1618
1623
|
cdr;
|
|
1619
1624
|
http;
|
|
1625
|
+
fxBuilderWrapperService;
|
|
1620
1626
|
fb = inject(FormBuilder);
|
|
1621
1627
|
minDate = new Date();
|
|
1622
1628
|
maxDate = new Date();
|
|
1629
|
+
fxComponent;
|
|
1630
|
+
destroy$ = new Subject();
|
|
1631
|
+
datePickerMap = new Map();
|
|
1623
1632
|
datePickerForm = this.fb.group({
|
|
1624
1633
|
date: ['', Validators.required],
|
|
1625
1634
|
});
|
|
1626
|
-
constructor(cdr, http) {
|
|
1635
|
+
constructor(cdr, http, fxBuilderWrapperService) {
|
|
1627
1636
|
super(cdr);
|
|
1628
1637
|
this.cdr = cdr;
|
|
1629
1638
|
this.http = http;
|
|
1639
|
+
this.fxBuilderWrapperService = fxBuilderWrapperService;
|
|
1630
1640
|
this.onInit.subscribe(() => {
|
|
1631
1641
|
this._register(this.datePickerForm);
|
|
1632
1642
|
});
|
|
1633
1643
|
}
|
|
1634
1644
|
ngOnInit() {
|
|
1645
|
+
this.fxBuilderWrapperService.variables$
|
|
1646
|
+
.pipe(takeUntil(this.destroy$))
|
|
1647
|
+
.subscribe((variables) => {
|
|
1648
|
+
if (!variables)
|
|
1649
|
+
return;
|
|
1650
|
+
this.datePickerMap = new Map();
|
|
1651
|
+
for (const [key, value] of Object.entries(variables)) {
|
|
1652
|
+
if (key.includes('lib-date-picker')) {
|
|
1653
|
+
this.datePickerMap.set(key, value);
|
|
1654
|
+
}
|
|
1655
|
+
}
|
|
1656
|
+
// You can now use datePickerMap as needed
|
|
1657
|
+
console.log('Date Picker Variables:', this.datePickerMap);
|
|
1658
|
+
});
|
|
1635
1659
|
const today = new Date();
|
|
1636
1660
|
this.minDate = new Date(today);
|
|
1637
1661
|
this.minDate.setDate(today.getDate() - 30);
|
|
@@ -1642,6 +1666,13 @@ class DatePickerComponent extends FxBaseComponent {
|
|
|
1642
1666
|
get dateControl() {
|
|
1643
1667
|
return this.datePickerForm.get('date');
|
|
1644
1668
|
}
|
|
1669
|
+
ngAfterViewInit() {
|
|
1670
|
+
const key = this.fxComponent?.fxData?.name;
|
|
1671
|
+
if (key) {
|
|
1672
|
+
this.datePickerForm.patchValue({ date: this.datePickerMap.get(key) });
|
|
1673
|
+
}
|
|
1674
|
+
this.getContextBaseId();
|
|
1675
|
+
}
|
|
1645
1676
|
getRangeValues() {
|
|
1646
1677
|
this.http.get(this.setting('apiURL')).subscribe(response => {
|
|
1647
1678
|
const today = new Date();
|
|
@@ -1665,13 +1696,16 @@ class DatePickerComponent extends FxBaseComponent {
|
|
|
1665
1696
|
validations() {
|
|
1666
1697
|
return [FxValidatorService.required];
|
|
1667
1698
|
}
|
|
1668
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DatePickerComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1$2.HttpClient }], target: i0.ɵɵFactoryTarget.Component });
|
|
1669
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DatePickerComponent, isStandalone: true, selector: "lib-date-picker", usesInheritance: true, ngImport: i0, template: "<fx-component [fxData]=\"fxData\">\r\n <div class=\"
|
|
1699
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DatePickerComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1$2.HttpClient }, { token: FxBuilderWrapperService }], target: i0.ɵɵFactoryTarget.Component });
|
|
1700
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DatePickerComponent, isStandalone: true, selector: "lib-date-picker", viewQueries: [{ propertyName: "fxComponent", first: true, predicate: ["fxComponent"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<fx-component [fxData]=\"fxData\" #fxComponent>\r\n <div class=\"flex justify-content-center\">\r\n <form [formGroup]=\"datePickerForm\" class=\"flex flex-column gap-2\">\r\n <p-calendar \r\n formControlName=\"date\" \r\n [showIcon]=\"true\"\r\n [minDate]=\"minDate\"\r\n [maxDate]=\"maxDate\"\r\n dateFormat=\"dd/mm/yy\"\r\n [showButtonBar]=\"true\"\r\n ></p-calendar>\r\n \r\n <small *ngIf=\"datePickerForm.get('date')?.touched && datePickerForm.get('date')?.errors?.['required']\" class=\"text-red-500\">\r\n Date is required.\r\n </small>\r\n </form>\r\n </div>\r\n \r\n</fx-component>\r\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1$1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1$1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1$1.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: "component", type: i5$2.Calendar, selector: "p-calendar", inputs: ["iconDisplay", "style", "styleClass", "inputStyle", "inputId", "name", "inputStyleClass", "placeholder", "ariaLabelledBy", "ariaLabel", "iconAriaLabel", "disabled", "dateFormat", "multipleSeparator", "rangeSeparator", "inline", "showOtherMonths", "selectOtherMonths", "showIcon", "icon", "appendTo", "readonlyInput", "shortYearCutoff", "monthNavigator", "yearNavigator", "hourFormat", "timeOnly", "stepYearPicker", "stepHour", "stepMinute", "stepSecond", "showSeconds", "required", "showOnFocus", "showWeek", "startWeekFromFirstDayOfYear", "showClear", "dataType", "selectionMode", "maxDateCount", "showButtonBar", "todayButtonStyleClass", "clearButtonStyleClass", "autofocus", "autoZIndex", "baseZIndex", "panelStyleClass", "panelStyle", "keepInvalid", "hideOnDateTimeSelect", "touchUI", "timeSeparator", "focusTrap", "showTransitionOptions", "hideTransitionOptions", "tabindex", "variant", "minDate", "maxDate", "disabledDates", "disabledDays", "yearRange", "showTime", "responsiveOptions", "numberOfMonths", "firstDayOfWeek", "locale", "view", "defaultDate"], outputs: ["onFocus", "onBlur", "onClose", "onSelect", "onClear", "onInput", "onTodayClick", "onClearClick", "onMonthChange", "onYearChange", "onClickOutside", "onShow"] }] });
|
|
1670
1701
|
}
|
|
1671
1702
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DatePickerComponent, decorators: [{
|
|
1672
1703
|
type: Component,
|
|
1673
|
-
args: [{ selector: 'lib-date-picker', standalone: true, imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent, CalendarModule], template: "<fx-component [fxData]=\"fxData\">\r\n <div class=\"
|
|
1674
|
-
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1$2.HttpClient }]
|
|
1704
|
+
args: [{ selector: 'lib-date-picker', standalone: true, imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent, CalendarModule], template: "<fx-component [fxData]=\"fxData\" #fxComponent>\r\n <div class=\"flex justify-content-center\">\r\n <form [formGroup]=\"datePickerForm\" class=\"flex flex-column gap-2\">\r\n <p-calendar \r\n formControlName=\"date\" \r\n [showIcon]=\"true\"\r\n [minDate]=\"minDate\"\r\n [maxDate]=\"maxDate\"\r\n dateFormat=\"dd/mm/yy\"\r\n [showButtonBar]=\"true\"\r\n ></p-calendar>\r\n \r\n <small *ngIf=\"datePickerForm.get('date')?.touched && datePickerForm.get('date')?.errors?.['required']\" class=\"text-red-500\">\r\n Date is required.\r\n </small>\r\n </form>\r\n </div>\r\n \r\n</fx-component>\r\n" }]
|
|
1705
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1$2.HttpClient }, { type: FxBuilderWrapperService }], propDecorators: { fxComponent: [{
|
|
1706
|
+
type: ViewChild,
|
|
1707
|
+
args: ['fxComponent']
|
|
1708
|
+
}] } });
|
|
1675
1709
|
|
|
1676
1710
|
class FxBuilderWrapperComponent {
|
|
1677
1711
|
fxWrapperService;
|
|
@@ -1790,7 +1824,8 @@ class FxFormWrapperComponent {
|
|
|
1790
1824
|
{ name: 'Toggle Button', key: 'toggle-button', component: ToggleButtonComponent },
|
|
1791
1825
|
{ name: 'Uploader', key: 'uploader', component: UploaderComponent },
|
|
1792
1826
|
{ name: 'Toggle', key: 'toggle', component: ToggleComponent },
|
|
1793
|
-
{ name: 'Uploader with Checkbox', key: 'uploader-checkbox', component: UploaderCheckboxComponent }
|
|
1827
|
+
{ name: 'Uploader with Checkbox', key: 'uploader-checkbox', component: UploaderCheckboxComponent },
|
|
1828
|
+
{ name: 'Date Picker', key: 'lib-date-picker', component: DatePickerComponent }
|
|
1794
1829
|
];
|
|
1795
1830
|
components.forEach(({ name, key, component }) => {
|
|
1796
1831
|
if (!this.fxWrapperService.getComponent(key)) {
|