fx-form-builder-wrapper 2.0.63 → 2.0.64
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 +13 -14
- package/esm2022/lib/components/dropdown-with-other/dropdown-with-other.component.mjs +35 -10
- package/esm2022/lib/components/fx-form-component/fx-form-component.component.mjs +4 -2
- package/esm2022/lib/components/radio-group/radio-group.component.mjs +112 -0
- package/esm2022/lib/components/uploader/uploader.component.mjs +4 -2
- package/esm2022/lib/fx-builder-wrapper.component.mjs +5 -1
- package/fesm2022/fx-form-builder-wrapper.mjs +156 -26
- package/fesm2022/fx-form-builder-wrapper.mjs.map +1 -1
- package/lib/components/dropdown-with-other/dropdown-with-other.component.d.ts +3 -1
- package/lib/components/radio-group/radio-group.component.d.ts +31 -0
- package/package.json +1 -1
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
import { Component, inject, Input, ViewChild } from '@angular/core';
|
|
2
|
+
import { FormBuilder, FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
3
|
+
import { FxBaseComponent, FxComponent, FxOptionSetting, FxStringSetting } from '@instantsys-labs/fx';
|
|
4
|
+
import { Subject, takeUntil } from 'rxjs';
|
|
5
|
+
import { CommonModule } from '@angular/common';
|
|
6
|
+
import { CalendarModule } from 'primeng/calendar';
|
|
7
|
+
import { RadioButtonModule } from 'primeng/radiobutton';
|
|
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
|
+
export class RadioGroupComponent extends FxBaseComponent {
|
|
15
|
+
cdr;
|
|
16
|
+
http;
|
|
17
|
+
fxBuilderWrapperService;
|
|
18
|
+
fxApiService;
|
|
19
|
+
fb = inject(FormBuilder);
|
|
20
|
+
destroy$ = new Subject();
|
|
21
|
+
formObject = {};
|
|
22
|
+
showOnSelection = 'yes'; // configurable: show textarea on Yes or No
|
|
23
|
+
showTextArea = false;
|
|
24
|
+
confirmationForm = this.fb.group({
|
|
25
|
+
confirmation: [''],
|
|
26
|
+
remarks: ['']
|
|
27
|
+
});
|
|
28
|
+
options = [
|
|
29
|
+
{ option: 'Yes', value: 'YES' },
|
|
30
|
+
{ option: 'No', value: 'NO' },
|
|
31
|
+
{ option: 'NA', value: 'NA' }
|
|
32
|
+
];
|
|
33
|
+
fxComponent;
|
|
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.confirmationForm);
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
ngAfterViewInit() {
|
|
45
|
+
this.options = this.fxComponent?.fxData?.settings?.find((s) => s.key === 'items')?.options || [];
|
|
46
|
+
setTimeout(() => {
|
|
47
|
+
this.confirmationForm.patchValue(this.formObject);
|
|
48
|
+
console.log('Patched formObject:', this.fxComponent);
|
|
49
|
+
}, 100);
|
|
50
|
+
}
|
|
51
|
+
ngOnInit() {
|
|
52
|
+
this.fxBuilderWrapperService.variables$
|
|
53
|
+
.pipe(takeUntil(this.destroy$))
|
|
54
|
+
.subscribe((variables) => {
|
|
55
|
+
if (!variables)
|
|
56
|
+
return;
|
|
57
|
+
for (const [key, value] of Object.entries(variables)) {
|
|
58
|
+
if (key.includes('radio-group-custom')) {
|
|
59
|
+
this.formObject = value;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
});
|
|
63
|
+
this.options = this.fxComponent?.fxData?.settings?.find((s) => s.key === 'items')?.options || [];
|
|
64
|
+
// this.setting('items').length > 0 ? this.options = this.setting('items') : null;
|
|
65
|
+
// this.dropDownForm.get('selectedOption')?.valueChanges.subscribe(value => {
|
|
66
|
+
// const otherControl = this.dropDownForm.get('otherInput');
|
|
67
|
+
// if (value === 'other') {
|
|
68
|
+
// otherControl?.enable();
|
|
69
|
+
// } else {
|
|
70
|
+
// otherControl?.disable();
|
|
71
|
+
// otherControl?.reset();
|
|
72
|
+
// }
|
|
73
|
+
// });
|
|
74
|
+
}
|
|
75
|
+
settings() {
|
|
76
|
+
return [
|
|
77
|
+
// new FxStringSetting({ key: 'clinicalNotesURL', $title: 'API Url', value: '' }),
|
|
78
|
+
// new FxStringSetting({ key: 'customClass', $title: 'Custom Class Name', value: '' }),
|
|
79
|
+
new FxStringSetting({ key: 'select-label', $title: 'Header Label', value: 'Header Label' }),
|
|
80
|
+
// new FxStringSetting({ key: 'option-value-one', $title: 'Value one', value: 'Value one' }),
|
|
81
|
+
// new FxStringSetting({ key: 'option-value-two', $title: 'Value two', value: 'Value two' }),
|
|
82
|
+
// new FxStringSetting({ key: 'option-label-one', $title: 'Label one', value: 'Label one' }),
|
|
83
|
+
// new FxStringSetting({ key: 'option-label-two', $title: 'Label two', value: 'Label two' }),
|
|
84
|
+
new FxStringSetting({ key: 'value-show-text', $title: 'Value to show textarea', value: 'Value to show textarea' }),
|
|
85
|
+
new FxOptionSetting({ key: 'items', $title: 'Options', value: [{ option: 'Yes', value: 'yes' }, { option: 'No', value: 'no' }] }, [{ option: 'Yes', value: 'yes' }, { option: 'No', value: 'no' }]),
|
|
86
|
+
// new FxStringSetting({ key: 'other-label', $title: 'Other Label', value: '' }),
|
|
87
|
+
// new FxStringSetting({ key: 'other-placeholder', $title: 'Other Placeholder', value: '' }),
|
|
88
|
+
// 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'}]),
|
|
89
|
+
// // new FxSelectSetting({key: 'service', $title: 'Service', value: 'local'}, [{option: 'Local', value: 'local'}, {option: 'QA', value: 'qa'},{option: 'UAT', value: 'uat'},{option: 'Production', value: 'prod'}]),
|
|
90
|
+
// // new FxSelectSetting({key: 'isRequired', $title: 'Required', value: true}, [{option: 'Yes', value: true}, {option: 'No', value: false}]),
|
|
91
|
+
// new FxStringSetting({ key: 'errorMessage', $title: 'Error Message', value: 'Please fill out the field' }),
|
|
92
|
+
];
|
|
93
|
+
}
|
|
94
|
+
validations() {
|
|
95
|
+
return [];
|
|
96
|
+
}
|
|
97
|
+
onSelectionChange(selection) {
|
|
98
|
+
this.showTextArea = selection === this.setting('value-show-text');
|
|
99
|
+
}
|
|
100
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RadioGroupComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.HttpClient }, { token: i2.FxBuilderWrapperService }, { token: i3.ApiServiceRegistry }], target: i0.ɵɵFactoryTarget.Component });
|
|
101
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: RadioGroupComponent, isStandalone: true, selector: "radio-group-custom", inputs: { showOnSelection: "showOnSelection" }, viewQueries: [{ propertyName: "fxComponent", first: true, predicate: ["fxComponent"], descendants: true }], usesInheritance: true, ngImport: i0, template: "\r\n<fx-component [fxData]=\"fxData\" #fxComponent>\r\n\r\n\r\n\r\n<form [formGroup]=\"confirmationForm\" class=\"flex flex-col gap-2\">\r\n <!-- Heading -->\r\n <label class=\"font-semibold mb-1\">{{ setting('select-label') }}</label>\r\n\r\n <!-- Radio buttons + textarea in same row -->\r\n <div class=\"flex items-center gap-4\">\r\n <!-- Dynamic radio buttons -->\r\n <div class=\"flex items-center gap-3\">\r\n <label\r\n *ngFor=\"let opt of options\"\r\n class=\"flex items-center gap-1 cursor-pointer\"\r\n >\r\n <input\r\n type=\"radio\"\r\n formControlName=\"confirmation\"\r\n [value]=\"opt.value\"\r\n (change)=\"onSelectionChange(opt.value)\"\r\n class=\"accent-blue-600\"\r\n />\r\n <span>{{ opt.option }}</span>\r\n </label>\r\n </div>\r\n\r\n <!-- Textarea (inline with radios) -->\r\n <textarea\r\n *ngIf=\"showTextArea\"\r\n formControlName=\"remarks\"\r\n rows=\"2\"\r\n placeholder=\"Enter details...\"\r\n class=\"border border-gray-300 rounded-md p-2 w-64 resize-none focus:outline-none focus:ring-2 focus:ring-blue-500\"\r\n ></textarea>\r\n </div>\r\n</form>\r\n\r\n\r\n\r\n</fx-component>\r\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i5.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.RadioControlValueAccessor, selector: "input[type=radio][formControlName],input[type=radio][formControl],input[type=radio][ngModel]", inputs: ["name", "formControlName", "value"] }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i5.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i5.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: FormsModule }, { kind: "component", type: FxComponent, selector: "fx-component", inputs: ["fxData"] }, { kind: "ngmodule", type: CalendarModule }, { kind: "ngmodule", type: RadioButtonModule }] });
|
|
102
|
+
}
|
|
103
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RadioGroupComponent, decorators: [{
|
|
104
|
+
type: Component,
|
|
105
|
+
args: [{ selector: 'radio-group-custom', standalone: true, imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent, CalendarModule, RadioButtonModule], template: "\r\n<fx-component [fxData]=\"fxData\" #fxComponent>\r\n\r\n\r\n\r\n<form [formGroup]=\"confirmationForm\" class=\"flex flex-col gap-2\">\r\n <!-- Heading -->\r\n <label class=\"font-semibold mb-1\">{{ setting('select-label') }}</label>\r\n\r\n <!-- Radio buttons + textarea in same row -->\r\n <div class=\"flex items-center gap-4\">\r\n <!-- Dynamic radio buttons -->\r\n <div class=\"flex items-center gap-3\">\r\n <label\r\n *ngFor=\"let opt of options\"\r\n class=\"flex items-center gap-1 cursor-pointer\"\r\n >\r\n <input\r\n type=\"radio\"\r\n formControlName=\"confirmation\"\r\n [value]=\"opt.value\"\r\n (change)=\"onSelectionChange(opt.value)\"\r\n class=\"accent-blue-600\"\r\n />\r\n <span>{{ opt.option }}</span>\r\n </label>\r\n </div>\r\n\r\n <!-- Textarea (inline with radios) -->\r\n <textarea\r\n *ngIf=\"showTextArea\"\r\n formControlName=\"remarks\"\r\n rows=\"2\"\r\n placeholder=\"Enter details...\"\r\n class=\"border border-gray-300 rounded-md p-2 w-64 resize-none focus:outline-none focus:ring-2 focus:ring-blue-500\"\r\n ></textarea>\r\n </div>\r\n</form>\r\n\r\n\r\n\r\n</fx-component>\r\n" }]
|
|
106
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.HttpClient }, { type: i2.FxBuilderWrapperService }, { type: i3.ApiServiceRegistry }], propDecorators: { showOnSelection: [{
|
|
107
|
+
type: Input
|
|
108
|
+
}], fxComponent: [{
|
|
109
|
+
type: ViewChild,
|
|
110
|
+
args: ['fxComponent']
|
|
111
|
+
}] } });
|
|
112
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio-group.component.js","sourceRoot":"","sources":["../../../../../../projects/fx-builder-wrapper/src/lib/components/radio-group/radio-group.component.ts","../../../../../../projects/fx-builder-wrapper/src/lib/components/radio-group/radio-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\r\nimport { AfterViewInit, ChangeDetectorRef, Component, inject, Input, OnInit, ViewChild } from '@angular/core';\r\nimport { FormBuilder, FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { ApiServiceRegistry } from '@instantsys-labs/core';\r\nimport { FxBaseComponent, FxComponent, FxOptionSetting, FxSelectSetting, FxSetting, FxStringSetting, FxValidation, FxValidatorService } from '@instantsys-labs/fx';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { FxBuilderWrapperService } from '../../fx-builder-wrapper.service';\r\nimport { CommonModule } from '@angular/common';\r\nimport { CalendarModule } from 'primeng/calendar';\r\nimport { RadioButtonModule } from 'primeng/radiobutton';\r\n\r\n@Component({\r\n  selector: 'radio-group-custom',\r\n  standalone: true,\r\n  imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent, CalendarModule,RadioButtonModule],\r\n  templateUrl: './radio-group.component.html',\r\n  styleUrl: './radio-group.component.css'\r\n})\r\nexport class RadioGroupComponent extends FxBaseComponent implements OnInit, AfterViewInit{\r\nprivate fb = inject(FormBuilder);\r\nprivate destroy$ = new Subject<Boolean>();\r\nformObject: object = {};\r\n@Input() showOnSelection: 'yes' | 'no' = 'yes'; // configurable: show textarea on Yes or No\r\n  showTextArea = false;\r\n public confirmationForm = this.fb.group({\r\n      confirmation: [''],\r\n      remarks: ['']\r\n    });\r\n\r\n    options: any[] = [\r\n      { option: 'Yes', value: 'YES' },\r\n      { option: 'No', value: 'NO' },\r\n      { option: 'NA', value: 'NA' }\r\n    ];\r\n\r\n    @ViewChild('fxComponent') fxComponent!: FxComponent;\r\n\r\n    constructor(private cdr: ChangeDetectorRef,private http: HttpClient,private fxBuilderWrapperService: FxBuilderWrapperService,private fxApiService: ApiServiceRegistry) {\r\n       super(cdr)\r\n        this.onInit.subscribe(() => {\r\n          this._register(this.confirmationForm);\r\n        });\r\n       \r\n     }\r\n\r\n       ngAfterViewInit(): void {\r\n        this.options  = (this.fxComponent?.fxData?.settings?.find((s: any) => s.key === 'items') as any)?.options || [];\r\n         setTimeout(()=>{\r\n      this.confirmationForm.patchValue(this.formObject);\r\n      console.log('Patched formObject:', this.fxComponent);\r\n         },100)\r\n\r\n        \r\n       }\r\n     \r\n       ngOnInit(): void {\r\n           this.fxBuilderWrapperService.variables$\r\n          .pipe(takeUntil(this.destroy$))\r\n          .subscribe((variables: any) => {\r\n            if (!variables) return;\r\n        \r\n        \r\n            for (const [key, value] of Object.entries(variables) as [string, any][]) {\r\n              if (key.includes('radio-group-custom')) {\r\n               this.formObject = value;\r\n              }\r\n            }\r\n       })\r\n\r\n        this.options  = (this.fxComponent?.fxData?.settings?.find((s: any) => s.key === 'items') as any)?.options || [];\r\n\r\n\r\n      //  this.setting('items').length > 0 ? this.options = this.setting('items') : null;\r\n     \r\n       //  this.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       \r\n     \r\n     }\r\n\r\n     protected settings(): FxSetting[] {\r\n          return [\r\n            // new FxStringSetting({ key: 'clinicalNotesURL', $title: 'API Url', value: '' }),\r\n            // new FxStringSetting({ key: 'customClass', $title: 'Custom Class Name', value: '' }),\r\n             new FxStringSetting({ key: 'select-label', $title: 'Header Label', value: 'Header Label' }), \r\n              // new FxStringSetting({ key: 'option-value-one', $title: 'Value one', value: 'Value one' }), \r\n              //  new FxStringSetting({ key: 'option-value-two', $title: 'Value two', value: 'Value two' }), \r\n              //   new FxStringSetting({ key: 'option-label-one', $title: 'Label one', value: 'Label one' }), \r\n              //   new FxStringSetting({ key: 'option-label-two', $title: 'Label two', value: 'Label two' }), \r\n                new FxStringSetting({ key: 'value-show-text', $title: 'Value to show textarea', value: 'Value to show textarea' }),\r\n                 new FxOptionSetting({ key: 'items', $title: 'Options', value: [{option: 'Yes', value: 'yes'}, {option: 'No', value: 'no'}]  }, [{option: 'Yes', value: 'yes'}, {option: 'No', value: 'no'}]), \r\n            //  new FxStringSetting({ key: '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          ];\r\n        }\r\n      \r\n        protected validations(): FxValidation[] {\r\n          return [];\r\n        }\r\n\r\n        onSelectionChange(selection: string) {\r\n    this.showTextArea = selection === this.setting('value-show-text');\r\n  }\r\n}\r\n","\r\n<fx-component [fxData]=\"fxData\" #fxComponent>\r\n\r\n\r\n\r\n<form [formGroup]=\"confirmationForm\" class=\"flex flex-col gap-2\">\r\n  <!-- Heading -->\r\n  <label class=\"font-semibold mb-1\">{{ setting('select-label') }}</label>\r\n\r\n  <!-- Radio buttons + textarea in same row -->\r\n  <div class=\"flex items-center gap-4\">\r\n    <!-- Dynamic radio buttons -->\r\n    <div class=\"flex items-center gap-3\">\r\n      <label\r\n        *ngFor=\"let opt of options\"\r\n        class=\"flex items-center gap-1 cursor-pointer\"\r\n      >\r\n        <input\r\n          type=\"radio\"\r\n          formControlName=\"confirmation\"\r\n          [value]=\"opt.value\"\r\n          (change)=\"onSelectionChange(opt.value)\"\r\n          class=\"accent-blue-600\"\r\n        />\r\n        <span>{{ opt.option }}</span>\r\n      </label>\r\n    </div>\r\n\r\n    <!-- Textarea (inline with radios) -->\r\n    <textarea\r\n      *ngIf=\"showTextArea\"\r\n      formControlName=\"remarks\"\r\n      rows=\"2\"\r\n      placeholder=\"Enter details...\"\r\n      class=\"border border-gray-300 rounded-md p-2 w-64 resize-none focus:outline-none focus:ring-2 focus:ring-blue-500\"\r\n    ></textarea>\r\n  </div>\r\n</form>\r\n\r\n\r\n\r\n</fx-component>\r\n"]}
|