fx-form-builder-wrapper 2.0.26 → 2.0.28
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 +57 -15
- package/esm2022/lib/components/uploader/uploader.component.mjs +3 -3
- package/fesm2022/fx-form-builder-wrapper.mjs +66 -24
- package/fesm2022/fx-form-builder-wrapper.mjs.map +1 -1
- package/lib/components/dropdown-with-other/dropdown-with-other.component.d.ts +4 -1
- package/package.json +1 -1
|
@@ -1,36 +1,39 @@
|
|
|
1
1
|
import { CommonModule } from '@angular/common';
|
|
2
2
|
import { Component, inject } from '@angular/core';
|
|
3
|
-
import { FormBuilder, FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
4
|
-
import { FxBaseComponent, FxComponent, FxStringSetting, FxValidatorService } from '@instantsys-labs/fx';
|
|
3
|
+
import { FormBuilder, FormsModule, ReactiveFormsModule, Validators } from '@angular/forms';
|
|
4
|
+
import { FxBaseComponent, FxComponent, FxSelectSetting, FxStringSetting, FxValidatorService } from '@instantsys-labs/fx';
|
|
5
5
|
import { CalendarModule } from 'primeng/calendar';
|
|
6
6
|
import { Subject, takeUntil } from 'rxjs';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
import * as i1 from "@angular/common/http";
|
|
9
9
|
import * as i2 from "../../fx-builder-wrapper.service";
|
|
10
|
-
import * as i3 from "@
|
|
11
|
-
import * as i4 from "@angular/
|
|
10
|
+
import * as i3 from "@instantsys-labs/core";
|
|
11
|
+
import * as i4 from "@angular/common";
|
|
12
|
+
import * as i5 from "@angular/forms";
|
|
12
13
|
export class DropdownWithOtherComponent extends FxBaseComponent {
|
|
13
14
|
cdr;
|
|
14
15
|
http;
|
|
15
16
|
fxBuilderWrapperService;
|
|
17
|
+
fxApiService;
|
|
16
18
|
fb = inject(FormBuilder);
|
|
17
19
|
destroy$ = new Subject();
|
|
18
20
|
formObject = {};
|
|
19
21
|
options = [
|
|
20
|
-
{ optionValue: '1', optionName: '
|
|
21
|
-
{ optionValue: '2', optionName: '
|
|
22
|
+
{ optionValue: 'Clinical Notes 1', optionName: 'Clinical Notes 1' },
|
|
23
|
+
{ optionValue: 'Clinical Notes 2', optionName: 'Clinical Notes 2' },
|
|
24
|
+
{ optionValue: 'Clinical Notes 3', optionName: 'Clinical Notes 3' },
|
|
22
25
|
{ optionValue: 'other', optionName: 'Other' }
|
|
23
26
|
];
|
|
24
27
|
dropDownForm = this.fb.group({
|
|
25
28
|
selectedOption: ['', []],
|
|
26
|
-
otherInput: ['',
|
|
27
|
-
// config:['',[]]
|
|
29
|
+
otherInput: [{ value: '', disabled: true }],
|
|
28
30
|
});
|
|
29
|
-
constructor(cdr, http, fxBuilderWrapperService) {
|
|
31
|
+
constructor(cdr, http, fxBuilderWrapperService, fxApiService) {
|
|
30
32
|
super(cdr);
|
|
31
33
|
this.cdr = cdr;
|
|
32
34
|
this.http = http;
|
|
33
35
|
this.fxBuilderWrapperService = fxBuilderWrapperService;
|
|
36
|
+
this.fxApiService = fxApiService;
|
|
34
37
|
this.onInit.subscribe(() => {
|
|
35
38
|
this._register(this.dropDownForm);
|
|
36
39
|
});
|
|
@@ -52,23 +55,62 @@ export class DropdownWithOtherComponent extends FxBaseComponent {
|
|
|
52
55
|
}
|
|
53
56
|
}
|
|
54
57
|
});
|
|
58
|
+
// this.dropDownForm.get('selectedOption')?.valueChanges.subscribe(value => {
|
|
59
|
+
// const otherControl = this.dropDownForm.get('otherInput');
|
|
60
|
+
// if (value === 'other') {
|
|
61
|
+
// otherControl?.enable();
|
|
62
|
+
// } else {
|
|
63
|
+
// otherControl?.disable();
|
|
64
|
+
// otherControl?.reset();
|
|
65
|
+
// }
|
|
66
|
+
// });
|
|
67
|
+
// const serviceUrl = this.fxApiService.getServiceUrl(this.setting('serviceName'));
|
|
68
|
+
// this.getOptions(serviceUrl,this.setting('clinicalNotesURL'));
|
|
69
|
+
this.dropDownForm.get('selectedOption')?.valueChanges.subscribe(value => {
|
|
70
|
+
const otherControl = this.dropDownForm.get('otherInput');
|
|
71
|
+
if (value === 'other') {
|
|
72
|
+
otherControl?.enable();
|
|
73
|
+
otherControl?.setValidators([Validators.required]);
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
otherControl?.disable();
|
|
77
|
+
otherControl?.reset();
|
|
78
|
+
otherControl?.clearValidators(); //
|
|
79
|
+
}
|
|
80
|
+
otherControl?.updateValueAndValidity(); //
|
|
81
|
+
otherControl?.markAsTouched();
|
|
82
|
+
});
|
|
55
83
|
}
|
|
56
84
|
settings() {
|
|
57
85
|
return [
|
|
58
|
-
new FxStringSetting({ key: '
|
|
86
|
+
new FxStringSetting({ key: 'clinicalNotesURL', $title: 'API Url', value: '' }),
|
|
59
87
|
new FxStringSetting({ key: 'select-label', $title: 'Label', value: '' }),
|
|
60
88
|
new FxStringSetting({ key: 'other-label', $title: 'Other Label', value: '' }),
|
|
61
89
|
new FxStringSetting({ key: 'other-placeholder', $title: 'Other Placeholder', value: '' }),
|
|
90
|
+
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' }]),
|
|
91
|
+
// new FxSelectSetting({key: 'service', $title: 'Service', value: 'local'}, [{option: 'Local', value: 'local'}, {option: 'QA', value: 'qa'},{option: 'UAT', value: 'uat'},{option: 'Production', value: 'prod'}]),
|
|
62
92
|
];
|
|
63
93
|
}
|
|
64
94
|
validations() {
|
|
65
95
|
return [FxValidatorService.required];
|
|
66
96
|
}
|
|
67
|
-
|
|
68
|
-
|
|
97
|
+
getOptions(serviceUrl, url) {
|
|
98
|
+
const finalUrl = serviceUrl + url;
|
|
99
|
+
this.http.get(finalUrl).subscribe({
|
|
100
|
+
next: (response) => {
|
|
101
|
+
this.options = response;
|
|
102
|
+
console.log('Options:', this.options);
|
|
103
|
+
},
|
|
104
|
+
error: (err) => {
|
|
105
|
+
console.error('Error fetching options', err);
|
|
106
|
+
}
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DropdownWithOtherComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.HttpClient }, { token: i2.FxBuilderWrapperService }, { token: i3.ApiServiceRegistry }], target: i0.ɵɵFactoryTarget.Component });
|
|
110
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DropdownWithOtherComponent, isStandalone: true, selector: "dropdown-with-other", usesInheritance: true, ngImport: i0, template: "<fx-component [fxData]=\"fxData\" #fxComponent>\r\n <!-- <div class=\"flex justify-content-center relative\">\r\n <form [formGroup]=\"dropDownForm\" class=\"flex flex-column gap-2\">\r\n <label for=\"\" class=\"input-title\">{{ setting('label') }}</label>\r\n <select formControlName=\"selectedOption\" class=\"border p-2 rounded\">\r\n <option value=\"\">Select</option>\r\n <option *ngFor=\"let option of options\" [value]=\"option.optionValue\">\r\n {{ option?.optionName }}\r\n </option>\r\n </select>\r\n\r\n <label for=\"\" class=\"input-title\">{{ setting('label') }}</label>\r\n <input\r\n *ngIf=\"dropDownForm.get('selectedOption')?.value === 'other'\"\r\n type=\"text\"\r\n formControlName=\"otherInput\"\r\n placeholder=\"enter other notes\"\r\n class=\"border p-2 rounded flex-1\"\r\n />\r\n\r\n \r\n </form>\r\n </div> -->\r\n\r\n <div class=\"flex justify-center custom-dropdown\">\r\n <form [formGroup]=\"dropDownForm\" class=\"flex flex-row gap-4 items-start\">\r\n \r\n <!-- Dropdown -->\r\n <div class=\"flex flex-col w-1/2\">\r\n <div class=\"relative\">\r\n\r\n <!-- <label class=\"mb-1 font-semibold text-sm\"></label> -->\r\n <span class=\"input-label dark:text-gray-300\">{{ setting('select-label') }}</span>\r\n <select formControlName=\"selectedOption\" class=\"border p-2 rounded w-full\">\r\n <option value=\"\">Select</option>\r\n <option *ngFor=\"let option of options\" [value]=\"option.optionValue\">\r\n {{ option?.optionName }}\r\n </option>\r\n </select>\r\n </div>\r\n </div>\r\n\r\n <!-- Other input (only if 'Other' selected) -->\r\n <div class=\"flex flex-col w-1/2\">\r\n <div class=\"relative\">\r\n <label class=\"input-label dark:text-gray-300\">{{ setting('other-label') }}</label>\r\n <div class=\"relative\">\r\n <input\r\n type=\"text\"\r\n formControlName=\"otherInput\"\r\n placeholder=\"{{setting('other-placeholder')}}\"\r\n class=\"border p-2 rounded w-full\"\r\n />\r\n </div>\r\n <small *ngIf=\"dropDownForm.get('otherInput')?.touched && dropDownForm.get('otherInput')?.errors?.['required']\"\r\n class=\"text-red-500\">\r\n Other is required.\r\n </small>\r\n </div>\r\n </div>\r\n\r\n \r\n </form>\r\n</div>\r\n\r\n\r\n</fx-component>\r\n\r\n <!-- <small *ngIf=\"datePickerForm.get('date')?.touched && datePickerForm.get('date')?.errors?.['required']\"\r\n class=\"text-red-500\">\r\n Date is required.\r\n </small> -->", 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\";.formBuilder_dynamic_table{border:.6px solid #ccc}.formBuilder_dynamic_table>thead>tr{background-color:#4682b4;color:#fff}.formBuilder_dynamic_table>thead>tr>th{font-weight:400!important;padding:.25rem .55rem;font-size:.875rem;text-align:left}.formBuilder_dynamic_table>tbody>tr:nth-child(odd){background-color:#fff}.formBuilder_dynamic_table>tbody>tr:nth-child(2n){background-color:#f6f6f6}.formBuilder_dynamic_table>tbody>tr>td{text-align:left;padding:.25rem .55rem}[type=text],[type=email],[type=url],[type=password],[type=number],[type=date],[type=datetime-local],[type=month],[type=search],[type=tel],[type=time],[type=week],[multiple],textarea,select{border:1px solid #ccc;border-radius:4px;padding:4px}select:not([size]){background:url('data:image/svg+xml,<svg width=\"22\" height=\"20\" viewBox=\"0 0 26 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">%0D%0A <rect x=\"0.5\" width=\"24.766\" height=\"24\" rx=\"3\" fill=\"%23FF7900\" fill-opacity=\"0.1\"/>%0D%0A <path d=\"M12.8918 16.5019C12.7255 16.5019 12.5695 16.4736 12.4239 16.4169C12.2783 16.3602 12.1431 16.2628 12.0183 16.1248L6.27803 9.8162C6.04925 9.56477 5.92946 9.25025 5.91864 8.87265C5.90783 8.49505 6.02762 8.16956 6.27803 7.89619C6.50681 7.64476 6.79799 7.51905 7.15155 7.51905C7.50512 7.51905 7.7963 7.64476 8.02508 7.89619L12.8918 13.2105L17.7586 7.89619C17.9874 7.64476 18.2736 7.51356 18.6172 7.50259C18.9607 7.49162 19.2569 7.62282 19.5056 7.89619C19.7344 8.14762 19.8488 8.46762 19.8488 8.85619C19.8488 9.24477 19.7344 9.56477 19.5056 9.8162L13.7654 16.1248C13.6406 16.2619 13.5054 16.3593 13.3598 16.4169C13.2142 16.4745 13.0582 16.5028 12.8918 16.5019Z\" fill=\"%23FAA762\"/>%0D%0A</svg>%0D%0A') right .4rem center no-repeat #fff;border:1px solid #cdcdcd;padding:6px 30px 6px 10px;border-radius:4px;font-size:14px;font-weight:400;cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%!important}.dd_down_icon{background:#f3a04126;border-radius:3px!important;padding:2px}[type=checkbox]{padding:12px}[type=checkbox]:checked{background-color:#f3a041!important;padding:12px;background-size:1em 1em!important}[type=radio]{width:20px;height:20px}[type=radio]:checked{background-color:#f3a041!important;background-size:1.5em 1.5em}[type=checkbox]:focus,[type=radio]:focus{--tw-ring-color: #f3a041 !important}:is() .p-multiselect{height:37.6px!important;border:1px solid #cdcdcd}:is() .p-multiselect .p-multiselect-label{padding:.5rem .75rem}:is() .p-multiselect .p-multiselect-label .p-placeholder{color:#454545}:is() .p-multiselect .p-multiselect-trigger{width:2.5rem!important}.dd_down_icon span{color:#f3a041}.orientation{height:82%!important}.confirmation-dialog .p-dialog-content{text-align:center}\n"], 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.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i5.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { 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.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { 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 }] });
|
|
69
111
|
}
|
|
70
112
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DropdownWithOtherComponent, decorators: [{
|
|
71
113
|
type: Component,
|
|
72
|
-
args: [{ selector: 'dropdown-with-other', standalone: true, imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent, CalendarModule], template: "<fx-component [fxData]=\"fxData\" #fxComponent>\r\n <!-- <div class=\"flex justify-content-center relative\">\r\n <form [formGroup]=\"dropDownForm\" class=\"flex flex-column gap-2\">\r\n <label for=\"\" class=\"input-title\">{{ setting('label') }}</label>\r\n <select formControlName=\"selectedOption\" class=\"border p-2 rounded\">\r\n <option value=\"\">Select</option>\r\n <option *ngFor=\"let option of options\" [value]=\"option.optionValue\">\r\n {{ option?.optionName }}\r\n </option>\r\n </select>\r\n\r\n <label for=\"\" class=\"input-title\">{{ setting('label') }}</label>\r\n <input\r\n *ngIf=\"dropDownForm.get('selectedOption')?.value === 'other'\"\r\n type=\"text\"\r\n formControlName=\"otherInput\"\r\n placeholder=\"enter other notes\"\r\n class=\"border p-2 rounded flex-1\"\r\n />\r\n\r\n \r\n </form>\r\n </div> -->\r\n\r\n <div class=\"flex justify-center custom-dropdown\">\r\n <form [formGroup]=\"dropDownForm\" class=\"flex flex-row gap-4 items-start\">\r\n \r\n <!-- Dropdown -->\r\n <div class=\"flex flex-col w-1/2\">\r\n <div class=\"relative\">\r\n\r\n <!-- <label class=\"mb-1 font-semibold text-sm\"></label> -->\r\n <span class=\"input-label dark:text-gray-300\">{{ setting('select-label') }}</span>\r\n <select formControlName=\"selectedOption\" class=\"border p-2 rounded w-full\">\r\n <option value=\"\">Select</option>\r\n <option *ngFor=\"let option of options\" [value]=\"option.optionValue\">\r\n {{ option?.optionName }}\r\n </option>\r\n </select>\r\n </div>\r\n </div>\r\n\r\n <!-- Other input (only if 'Other' selected) -->\r\n <div class=\"flex flex-col w-1/2\">\r\n <div class=\"relative\">\r\n <label class=\"input-label dark:text-gray-300\">{{ setting('other-label') }}</label>\r\n <div class=\"relative\">\r\n <input\r\n type=\"text\"\r\n formControlName=\"otherInput\"\r\n placeholder=\"{{setting('other-placeholder')}}\"\r\n class=\"border p-2 rounded w-full\"\r\n
|
|
73
|
-
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.HttpClient }, { type: i2.FxBuilderWrapperService }] });
|
|
74
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-with-other.component.js","sourceRoot":"","sources":["../../../../../../projects/fx-builder-wrapper/src/lib/components/dropdown-with-other/dropdown-with-other.component.ts","../../../../../../projects/fx-builder-wrapper/src/lib/components/dropdown-with-other/dropdown-with-other.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAE/C,OAAO,EAAoC,SAAS,EAAE,MAAM,EAAU,MAAM,eAAe,CAAC;AAC5F,OAAO,EAAE,WAAW,EAAa,WAAW,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAC1F,OAAO,EAAE,eAAe,EAAE,WAAW,EAAa,eAAe,EAAgB,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AAEjI,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;;;;;;AAS1C,MAAM,OAAO,0BAA2B,SAAQ,eAAe;IAgBzC;IAA+B;IAAyB;IAftE,EAAE,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;IACzB,QAAQ,GAAG,IAAI,OAAO,EAAW,CAAC;IAC1C,UAAU,GAAW,EAAE,CAAC;IACxB,OAAO,GAAG;QACT,EAAE,WAAW,EAAE,GAAG,EAAE,UAAU,EAAE,UAAU,EAAE;QACvC,EAAE,WAAW,EAAE,GAAG,EAAE,UAAU,EAAE,UAAU,EAAE;QAC5C,EAAE,WAAW,EAAE,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE;KAClD,CAAC;IAEW,YAAY,GAAc,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;QAC5C,cAAc,EAAE,CAAC,EAAE,EAAC,EAAE,CAAC;QACvB,UAAU,EAAC,CAAC,EAAE,EAAC,EAAE,CAAC;QACnB,kBAAkB;KAClB,CAAC,CAAA;IAEP,YAAoB,GAAsB,EAAS,IAAgB,EAAS,uBAAgD;QACtH,KAAK,CAAC,GAAG,CAAC,CAAA;QADI,QAAG,GAAH,GAAG,CAAmB;QAAS,SAAI,GAAJ,IAAI,CAAY;QAAS,4BAAuB,GAAvB,uBAAuB,CAAyB;QAEtH,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,EAAE;YACzB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACpC,CAAC,CAAC,CAAC;IAEL,CAAC;IACL,eAAe;QACb,UAAU,CAAC,GAAE,EAAE;YAClB,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC3C,CAAC,EAAC,GAAG,CAAC,CAAA;IAER,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,uBAAuB,CAAC,UAAU;aACvC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC9B,SAAS,CAAC,CAAC,SAAc,EAAE,EAAE;YAC5B,IAAI,CAAC,SAAS;gBAAE,OAAO;YAGvB,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,SAAS,CAAoB,EAAE,CAAC;gBACxE,IAAI,GAAG,CAAC,QAAQ,CAAC,qBAAqB,CAAC,EAAE,CAAC;oBACzC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;gBACzB,CAAC;YACH,CAAC;QACN,CAAC,CAAC,CAAA;IACJ,CAAC;IAEe,QAAQ;QACd,OAAO;YACL,IAAI,eAAe,CAAC,EAAE,GAAG,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC;YACnE,IAAI,eAAe,CAAC,EAAE,GAAG,EAAE,cAAc,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC;YACxE,IAAI,eAAe,CAAC,EAAE,GAAG,EAAE,aAAa,EAAE,MAAM,EAAE,aAAa,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC;YAC5E,IAAI,eAAe,CAAC,EAAE,GAAG,EAAE,mBAAmB,EAAE,MAAM,EAAE,mBAAmB,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC;SAC5F,CAAC;IACJ,CAAC;IAES,WAAW;QACnB,OAAO,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC;IACvC,CAAC;wGAxDI,0BAA0B;4FAA1B,0BAA0B,sGChBvC,i8EAoEkB,47FDxDN,YAAY,2JAAE,mBAAmB,u2CAAE,WAAW,+BAAE,WAAW,4EAAE,cAAc;;4FAI1E,0BAA0B;kBAPtC,SAAS;+BACE,qBAAqB,cACnB,IAAI,WACP,CAAC,YAAY,EAAE,mBAAmB,EAAE,WAAW,EAAE,WAAW,EAAE,cAAc,CAAC","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { AfterViewInit, ChangeDetectorRef, Component, inject, OnInit } from '@angular/core';\r\nimport { FormBuilder, FormGroup, FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { FxBaseComponent, FxComponent, FxSetting, FxStringSetting, FxValidation, FxValidatorService } from '@instantsys-labs/fx';\r\nimport { FxBuilderWrapperService } from '../../fx-builder-wrapper.service';\r\nimport { CalendarModule } from 'primeng/calendar';\r\nimport { Subject, takeUntil } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'dropdown-with-other',\r\n  standalone: true,\r\n  imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent, CalendarModule],\r\n  templateUrl: './dropdown-with-other.component.html',\r\n  styleUrl: './dropdown-with-other.component.css'\r\n})\r\nexport class DropdownWithOtherComponent extends FxBaseComponent implements OnInit, AfterViewInit {\r\nprivate fb = inject(FormBuilder);\r\nprivate destroy$ = new Subject<Boolean>();\r\nformObject: object = {};\r\noptions = [\r\n { optionValue: '1', optionName: 'Option 1' },\r\n      { optionValue: '2', optionName: 'Option 2' },\r\n      { optionValue: 'other', optionName: 'Other' }\r\n];\r\n\r\n      public dropDownForm: FormGroup = this.fb.group({\r\n         selectedOption: ['',[]],\r\n         otherInput:['',[]],\r\n        //  config:['',[]]\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.dropDownForm);\r\n        });\r\n       \r\n      }\r\n  ngAfterViewInit(): void {\r\n    setTimeout(()=>{\r\n this.dropDownForm.patchValue(this.formObject);\r\n    },100)\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('dropdown-with-other')) {\r\n          this.formObject = value;\r\n         }\r\n       }\r\n  })\r\n}\r\n\r\n      protected settings(): FxSetting[] {\r\n          return [\r\n            new FxStringSetting({ key: 'apiURL', $title: 'API Url', value: '' }),\r\n             new FxStringSetting({ key: 'select-label', $title: 'Label', value: '' }), \r\n             new FxStringSetting({ key: 'other-label', $title: 'Other Label', value: '' }),\r\n              new FxStringSetting({ key: 'other-placeholder', $title: 'Other Placeholder', value: '' }),           \r\n          ];\r\n        }\r\n      \r\n        protected validations(): FxValidation[] {\r\n          return [FxValidatorService.required];\r\n        }\r\n\r\n}\r\n","<fx-component [fxData]=\"fxData\" #fxComponent>\r\n  <!-- <div class=\"flex justify-content-center relative\">\r\n    <form [formGroup]=\"dropDownForm\" class=\"flex flex-column gap-2\">\r\n   <label for=\"\" class=\"input-title\">{{ setting('label') }}</label>\r\n  <select formControlName=\"selectedOption\" class=\"border p-2 rounded\">\r\n    <option  value=\"\">Select</option>\r\n    <option *ngFor=\"let option of options\" [value]=\"option.optionValue\">\r\n      {{ option?.optionName }}\r\n    </option>\r\n  </select>\r\n\r\n   <label for=\"\" class=\"input-title\">{{ setting('label') }}</label>\r\n  <input\r\n    *ngIf=\"dropDownForm.get('selectedOption')?.value === 'other'\"\r\n    type=\"text\"\r\n    formControlName=\"otherInput\"\r\n    placeholder=\"enter other notes\"\r\n    class=\"border p-2 rounded flex-1\"\r\n  />\r\n\r\n  \r\n    </form>\r\n  </div> -->\r\n\r\n  <div class=\"flex justify-center custom-dropdown\">\r\n  <form [formGroup]=\"dropDownForm\" class=\"flex flex-row gap-4 items-start\">\r\n    \r\n    <!-- Dropdown -->\r\n    <div class=\"flex flex-col w-1/2\">\r\n      <div class=\"relative\">\r\n\r\n      <!-- <label class=\"mb-1 font-semibold text-sm\"></label> -->\r\n      <span  class=\"input-label dark:text-gray-300\">{{ setting('select-label') }}</span>\r\n      <select formControlName=\"selectedOption\" class=\"border p-2 rounded w-full\">\r\n        <option value=\"\">Select</option>\r\n        <option *ngFor=\"let option of options\" [value]=\"option.optionValue\">\r\n          {{ option?.optionName }}\r\n        </option>\r\n      </select>\r\n      </div>\r\n    </div>\r\n\r\n    <!-- Other input (only if 'Other' selected) -->\r\n    <div class=\"flex flex-col w-1/2\">\r\n      <div class=\"relative\">\r\n      <label class=\"input-label dark:text-gray-300\">{{ setting('other-label') }}</label>\r\n      <div class=\"relative\">\r\n      <input\r\n        type=\"text\"\r\n        formControlName=\"otherInput\"\r\n        placeholder=\"{{setting('other-placeholder')}}\"\r\n        class=\"border p-2 rounded w-full\"\r\n        [disabled]=\"dropDownForm.get('selectedOption')?.value !== 'other'\"\r\n      />\r\n      </div>\r\n      </div>\r\n    </div>\r\n\r\n    \r\n  </form>\r\n</div>\r\n\r\n\r\n</fx-component>\r\n\r\n      <!-- <small *ngIf=\"datePickerForm.get('date')?.touched && datePickerForm.get('date')?.errors?.['required']\"\r\n        class=\"text-red-500\">\r\n        Date is required.\r\n      </small> -->"]}
|
|
114
|
+
args: [{ selector: 'dropdown-with-other', standalone: true, imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent, CalendarModule], template: "<fx-component [fxData]=\"fxData\" #fxComponent>\r\n <!-- <div class=\"flex justify-content-center relative\">\r\n <form [formGroup]=\"dropDownForm\" class=\"flex flex-column gap-2\">\r\n <label for=\"\" class=\"input-title\">{{ setting('label') }}</label>\r\n <select formControlName=\"selectedOption\" class=\"border p-2 rounded\">\r\n <option value=\"\">Select</option>\r\n <option *ngFor=\"let option of options\" [value]=\"option.optionValue\">\r\n {{ option?.optionName }}\r\n </option>\r\n </select>\r\n\r\n <label for=\"\" class=\"input-title\">{{ setting('label') }}</label>\r\n <input\r\n *ngIf=\"dropDownForm.get('selectedOption')?.value === 'other'\"\r\n type=\"text\"\r\n formControlName=\"otherInput\"\r\n placeholder=\"enter other notes\"\r\n class=\"border p-2 rounded flex-1\"\r\n />\r\n\r\n \r\n </form>\r\n </div> -->\r\n\r\n <div class=\"flex justify-center custom-dropdown\">\r\n <form [formGroup]=\"dropDownForm\" class=\"flex flex-row gap-4 items-start\">\r\n \r\n <!-- Dropdown -->\r\n <div class=\"flex flex-col w-1/2\">\r\n <div class=\"relative\">\r\n\r\n <!-- <label class=\"mb-1 font-semibold text-sm\"></label> -->\r\n <span class=\"input-label dark:text-gray-300\">{{ setting('select-label') }}</span>\r\n <select formControlName=\"selectedOption\" class=\"border p-2 rounded w-full\">\r\n <option value=\"\">Select</option>\r\n <option *ngFor=\"let option of options\" [value]=\"option.optionValue\">\r\n {{ option?.optionName }}\r\n </option>\r\n </select>\r\n </div>\r\n </div>\r\n\r\n <!-- Other input (only if 'Other' selected) -->\r\n <div class=\"flex flex-col w-1/2\">\r\n <div class=\"relative\">\r\n <label class=\"input-label dark:text-gray-300\">{{ setting('other-label') }}</label>\r\n <div class=\"relative\">\r\n <input\r\n type=\"text\"\r\n formControlName=\"otherInput\"\r\n placeholder=\"{{setting('other-placeholder')}}\"\r\n class=\"border p-2 rounded w-full\"\r\n />\r\n </div>\r\n <small *ngIf=\"dropDownForm.get('otherInput')?.touched && dropDownForm.get('otherInput')?.errors?.['required']\"\r\n class=\"text-red-500\">\r\n Other is required.\r\n </small>\r\n </div>\r\n </div>\r\n\r\n \r\n </form>\r\n</div>\r\n\r\n\r\n</fx-component>\r\n\r\n <!-- <small *ngIf=\"datePickerForm.get('date')?.touched && datePickerForm.get('date')?.errors?.['required']\"\r\n class=\"text-red-500\">\r\n Date is required.\r\n </small> -->", 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\";.formBuilder_dynamic_table{border:.6px solid #ccc}.formBuilder_dynamic_table>thead>tr{background-color:#4682b4;color:#fff}.formBuilder_dynamic_table>thead>tr>th{font-weight:400!important;padding:.25rem .55rem;font-size:.875rem;text-align:left}.formBuilder_dynamic_table>tbody>tr:nth-child(odd){background-color:#fff}.formBuilder_dynamic_table>tbody>tr:nth-child(2n){background-color:#f6f6f6}.formBuilder_dynamic_table>tbody>tr>td{text-align:left;padding:.25rem .55rem}[type=text],[type=email],[type=url],[type=password],[type=number],[type=date],[type=datetime-local],[type=month],[type=search],[type=tel],[type=time],[type=week],[multiple],textarea,select{border:1px solid #ccc;border-radius:4px;padding:4px}select:not([size]){background:url('data:image/svg+xml,<svg width=\"22\" height=\"20\" viewBox=\"0 0 26 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">%0D%0A <rect x=\"0.5\" width=\"24.766\" height=\"24\" rx=\"3\" fill=\"%23FF7900\" fill-opacity=\"0.1\"/>%0D%0A <path d=\"M12.8918 16.5019C12.7255 16.5019 12.5695 16.4736 12.4239 16.4169C12.2783 16.3602 12.1431 16.2628 12.0183 16.1248L6.27803 9.8162C6.04925 9.56477 5.92946 9.25025 5.91864 8.87265C5.90783 8.49505 6.02762 8.16956 6.27803 7.89619C6.50681 7.64476 6.79799 7.51905 7.15155 7.51905C7.50512 7.51905 7.7963 7.64476 8.02508 7.89619L12.8918 13.2105L17.7586 7.89619C17.9874 7.64476 18.2736 7.51356 18.6172 7.50259C18.9607 7.49162 19.2569 7.62282 19.5056 7.89619C19.7344 8.14762 19.8488 8.46762 19.8488 8.85619C19.8488 9.24477 19.7344 9.56477 19.5056 9.8162L13.7654 16.1248C13.6406 16.2619 13.5054 16.3593 13.3598 16.4169C13.2142 16.4745 13.0582 16.5028 12.8918 16.5019Z\" fill=\"%23FAA762\"/>%0D%0A</svg>%0D%0A') right .4rem center no-repeat #fff;border:1px solid #cdcdcd;padding:6px 30px 6px 10px;border-radius:4px;font-size:14px;font-weight:400;cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%!important}.dd_down_icon{background:#f3a04126;border-radius:3px!important;padding:2px}[type=checkbox]{padding:12px}[type=checkbox]:checked{background-color:#f3a041!important;padding:12px;background-size:1em 1em!important}[type=radio]{width:20px;height:20px}[type=radio]:checked{background-color:#f3a041!important;background-size:1.5em 1.5em}[type=checkbox]:focus,[type=radio]:focus{--tw-ring-color: #f3a041 !important}:is() .p-multiselect{height:37.6px!important;border:1px solid #cdcdcd}:is() .p-multiselect .p-multiselect-label{padding:.5rem .75rem}:is() .p-multiselect .p-multiselect-label .p-placeholder{color:#454545}:is() .p-multiselect .p-multiselect-trigger{width:2.5rem!important}.dd_down_icon span{color:#f3a041}.orientation{height:82%!important}.confirmation-dialog .p-dialog-content{text-align:center}\n"] }]
|
|
115
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.HttpClient }, { type: i2.FxBuilderWrapperService }, { type: i3.ApiServiceRegistry }] });
|
|
116
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-with-other.component.js","sourceRoot":"","sources":["../../../../../../projects/fx-builder-wrapper/src/lib/components/dropdown-with-other/dropdown-with-other.component.ts","../../../../../../projects/fx-builder-wrapper/src/lib/components/dropdown-with-other/dropdown-with-other.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { AfterViewInit, ChangeDetectorRef, Component, inject, OnInit } from '@angular/core';\r\nimport { FormBuilder, FormGroup, FormsModule, ReactiveFormsModule, Validators } from '@angular/forms';\r\nimport { FxBaseComponent, FxComponent, FxSelectSetting, FxSetting, FxStringSetting, FxValidation, FxValidatorService } from '@instantsys-labs/fx';\r\nimport { FxBuilderWrapperService } from '../../fx-builder-wrapper.service';\r\nimport { CalendarModule } from 'primeng/calendar';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { ApiServiceRegistry } from '@instantsys-labs/core'\r\n\r\n@Component({\r\n  selector: 'dropdown-with-other',\r\n  standalone: true,\r\n  imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent, CalendarModule],\r\n  templateUrl: './dropdown-with-other.component.html',\r\n  styleUrl: './dropdown-with-other.component.css'\r\n})\r\nexport class DropdownWithOtherComponent extends FxBaseComponent implements OnInit, AfterViewInit {\r\nprivate fb = inject(FormBuilder);\r\nprivate destroy$ = new Subject<Boolean>();\r\nformObject: object = {};\r\noptions = [\r\n      { optionValue: 'Clinical Notes 1', optionName: 'Clinical Notes 1' },\r\n      { optionValue: 'Clinical Notes 2', optionName: 'Clinical Notes 2' },\r\n      { optionValue: 'Clinical Notes 3', optionName: 'Clinical Notes 3' },\r\n      { optionValue: 'other', optionName: 'Other' }\r\n];\r\n\r\n     public dropDownForm: FormGroup = this.fb.group({\r\n  selectedOption: ['', []],\r\n  otherInput: [{ value: '', disabled: true }],\r\n});\r\n\r\n  constructor(private cdr: ChangeDetectorRef,private http: HttpClient,private fxBuilderWrapperService: FxBuilderWrapperService,private fxApiService: ApiServiceRegistry) {\r\n        super(cdr)\r\n        this.onInit.subscribe(() => {\r\n          this._register(this.dropDownForm);\r\n        });\r\n       \r\n      }\r\n  ngAfterViewInit(): void {\r\n    setTimeout(()=>{\r\n this.dropDownForm.patchValue(this.formObject);\r\n    },100)\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('dropdown-with-other')) {\r\n          this.formObject = value;\r\n         }\r\n       }\r\n  })\r\n\r\n  //  this.dropDownForm.get('selectedOption')?.valueChanges.subscribe(value => {\r\n  //   const otherControl = this.dropDownForm.get('otherInput');\r\n  //   if (value === 'other') {\r\n  //     otherControl?.enable();\r\n  //   } else {\r\n  //     otherControl?.disable();\r\n  //     otherControl?.reset();\r\n  //   }\r\n  // });\r\n  // const serviceUrl = this.fxApiService.getServiceUrl(this.setting('serviceName'));\r\n  // this.getOptions(serviceUrl,this.setting('clinicalNotesURL'));\r\n\r\n  this.dropDownForm.get('selectedOption')?.valueChanges.subscribe(value => {\r\n  const otherControl = this.dropDownForm.get('otherInput');\r\n\r\n  if (value === 'other') {\r\n    otherControl?.enable();\r\n    otherControl?.setValidators([Validators.required]);\r\n  } else {\r\n    otherControl?.disable();\r\n    otherControl?.reset();\r\n    otherControl?.clearValidators(); //\r\n  }\r\n\r\n  otherControl?.updateValueAndValidity(); //\r\n  otherControl?.markAsTouched();\r\n});\r\n\r\n}\r\n\r\n      protected settings(): FxSetting[] {\r\n          return [\r\n            new FxStringSetting({ key: 'clinicalNotesURL', $title: 'API Url', value: '' }),\r\n             new FxStringSetting({ key: 'select-label', $title: 'Label', value: '' }), \r\n             new FxStringSetting({ key: 'other-label', $title: 'Other Label', value: '' }),\r\n              new FxStringSetting({ key: 'other-placeholder', $title: 'Other Placeholder', value: '' }),  \r\n              new FxSelectSetting({key: 'serviceName', $title: 'Service', value: ''}, [{option: 'User Service', value: 'user_service'}, {option: 'Patient Service', value: 'patient_service'},{option: 'Workflow Service', value: 'workflow_service'}]),\r\n              // new FxSelectSetting({key: 'service', $title: 'Service', value: 'local'}, [{option: 'Local', value: 'local'}, {option: 'QA', value: 'qa'},{option: 'UAT', value: 'uat'},{option: 'Production', value: 'prod'}]),         \r\n          ];\r\n        }\r\n      \r\n        protected validations(): FxValidation[] {\r\n          return [FxValidatorService.required];\r\n        }\r\n\r\n  getOptions(serviceUrl:string,url: string) {\r\n    const finalUrl = serviceUrl + url;\r\n  this.http.get<any[]>(finalUrl).subscribe({\r\n    next: (response) => {\r\n      this.options = response;\r\n      console.log('Options:', this.options);\r\n    },\r\n    error: (err) => {\r\n      console.error('Error fetching options', err);\r\n    }\r\n  });\r\n\r\n}\r\n\r\n}\r\n","<fx-component [fxData]=\"fxData\" #fxComponent>\r\n  <!-- <div class=\"flex justify-content-center relative\">\r\n    <form [formGroup]=\"dropDownForm\" class=\"flex flex-column gap-2\">\r\n   <label for=\"\" class=\"input-title\">{{ setting('label') }}</label>\r\n  <select formControlName=\"selectedOption\" class=\"border p-2 rounded\">\r\n    <option  value=\"\">Select</option>\r\n    <option *ngFor=\"let option of options\" [value]=\"option.optionValue\">\r\n      {{ option?.optionName }}\r\n    </option>\r\n  </select>\r\n\r\n   <label for=\"\" class=\"input-title\">{{ setting('label') }}</label>\r\n  <input\r\n    *ngIf=\"dropDownForm.get('selectedOption')?.value === 'other'\"\r\n    type=\"text\"\r\n    formControlName=\"otherInput\"\r\n    placeholder=\"enter other notes\"\r\n    class=\"border p-2 rounded flex-1\"\r\n  />\r\n\r\n  \r\n    </form>\r\n  </div> -->\r\n\r\n  <div class=\"flex justify-center custom-dropdown\">\r\n  <form [formGroup]=\"dropDownForm\" class=\"flex flex-row gap-4 items-start\">\r\n    \r\n    <!-- Dropdown -->\r\n    <div class=\"flex flex-col w-1/2\">\r\n      <div class=\"relative\">\r\n\r\n      <!-- <label class=\"mb-1 font-semibold text-sm\"></label> -->\r\n      <span  class=\"input-label dark:text-gray-300\">{{ setting('select-label') }}</span>\r\n      <select formControlName=\"selectedOption\" class=\"border p-2 rounded w-full\">\r\n        <option value=\"\">Select</option>\r\n        <option *ngFor=\"let option of options\" [value]=\"option.optionValue\">\r\n          {{ option?.optionName }}\r\n        </option>\r\n      </select>\r\n      </div>\r\n    </div>\r\n\r\n    <!-- Other input (only if 'Other' selected) -->\r\n    <div class=\"flex flex-col w-1/2\">\r\n      <div class=\"relative\">\r\n      <label class=\"input-label dark:text-gray-300\">{{ setting('other-label') }}</label>\r\n      <div class=\"relative\">\r\n      <input\r\n        type=\"text\"\r\n        formControlName=\"otherInput\"\r\n        placeholder=\"{{setting('other-placeholder')}}\"\r\n        class=\"border p-2 rounded w-full\"\r\n      />\r\n      </div>\r\n      <small *ngIf=\"dropDownForm.get('otherInput')?.touched && dropDownForm.get('otherInput')?.errors?.['required']\"\r\n        class=\"text-red-500\">\r\n        Other is required.\r\n      </small>\r\n      </div>\r\n    </div>\r\n\r\n    \r\n  </form>\r\n</div>\r\n\r\n\r\n</fx-component>\r\n\r\n      <!-- <small *ngIf=\"datePickerForm.get('date')?.touched && datePickerForm.get('date')?.errors?.['required']\"\r\n        class=\"text-red-500\">\r\n        Date is required.\r\n      </small> -->"]}
|