@bsachref/ng-form 1.0.2

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.
@@ -0,0 +1,210 @@
1
+ /**
2
+ * PrimeNgFormsComponent is a standalone Angular component that dynamically generates
3
+ * a form based on the provided configuration. It leverages PrimeNG UI components
4
+ * and Angular Reactive Forms for form creation and validation.
5
+ *
6
+ * @selector primeng-forms
7
+ * @standalone true
8
+ * @imports [
9
+ * CommonModule,
10
+ * FormsModule,
11
+ * ReactiveFormsModule,
12
+ * ValidationMessagesComponent,
13
+ * InputTextModule,
14
+ * MultiSelectModule,
15
+ * TextareaModule,
16
+ * CheckboxModule,
17
+ * RadioButtonModule,
18
+ * DatePickerModule,
19
+ * ToggleButtonModule,
20
+ * FileUploadModule,
21
+ * SliderModule,
22
+ * ButtonModule,
23
+ * SelectModule,
24
+ * FileUploadValueAccessor
25
+ * ]
26
+ * @templateUrl ./prime-form.component.html
27
+ * @styleUrl ./prime-form.component.css
28
+ * @changeDetection ChangeDetectionStrategy.OnPush
29
+ *
30
+ * @property {string} formName - The name of the form.
31
+ * @property {FormControlConfig[]} controls - The configuration for the form controls.
32
+ * @property {EventEmitter<Record<string, any>>} formSubmit - Event emitter for form submission.
33
+ * @property {FormGroup} form - The reactive form group.
34
+ * @property {BehaviorSubject<boolean>} formChanges$ - Observable to track form changes.
35
+ *
36
+ * @constructor
37
+ * @param {FormBuilder} fb - FormBuilder service to create form controls.
38
+ * @param {ChangeDetectorRef} cdr - ChangeDetectorRef to manually trigger change detection.
39
+ *
40
+ * @method ngOnInit - Lifecycle hook that initializes the form.
41
+ * @method initializeForm - Initializes the form controls and sets up value change subscriptions.
42
+ * @method getValidators - Returns an array of validators for a given form control configuration.
43
+ * @param {FormControlConfig} control - The configuration for a form control.
44
+ * @returns {ValidatorFn[]} - An array of validator functions.
45
+ * @method updateValidators - Updates the validators for a form control based on its value.
46
+ * @param {AbstractControl} control - The form control to update.
47
+ * @param {any} value - The current value of the form control.
48
+ * @method shouldRequireValidation - Determines if a form control should require validation.
49
+ * @param {any} value - The current value of the form control.
50
+ * @returns {boolean} - True if validation is required, false otherwise.
51
+ * @method onFileSelect - Handles file selection for file upload controls.
52
+ * @param {any} event - The file selection event.
53
+ * @param {string} controlName - The name of the form control.
54
+ * @method onSubmit - Handles form submission, validates the form, and emits the form value.
55
+ */
56
+ import { CommonModule } from '@angular/common';
57
+ import { ChangeDetectionStrategy, Component, input, output, } from '@angular/core';
58
+ import { ReactiveFormsModule, FormsModule, Validators, } from '@angular/forms';
59
+ import { ValidationMessagesComponent } from '../validation-messages/validation-messages.component';
60
+ import { BehaviorSubject } from 'rxjs';
61
+ import { InputTextModule } from 'primeng/inputtext';
62
+ import { MultiSelectModule } from 'primeng/multiselect';
63
+ import { TextareaModule } from 'primeng/textarea';
64
+ import { CheckboxModule } from 'primeng/checkbox';
65
+ import { RadioButtonModule } from 'primeng/radiobutton';
66
+ import { ToggleButtonModule } from 'primeng/togglebutton';
67
+ import { FileUploadModule } from 'primeng/fileupload';
68
+ import { SliderModule } from 'primeng/slider';
69
+ import { ButtonModule } from 'primeng/button';
70
+ import { DatePickerModule } from 'primeng/datepicker';
71
+ import { SelectModule } from 'primeng/select';
72
+ import { FileUploadValueAccessor } from '../file-upload-accessor.directive';
73
+ import * as i0 from "@angular/core";
74
+ import * as i1 from "@angular/forms";
75
+ import * as i2 from "@angular/common";
76
+ import * as i3 from "primeng/inputtext";
77
+ import * as i4 from "primeng/multiselect";
78
+ import * as i5 from "primeng/textarea";
79
+ import * as i6 from "primeng/checkbox";
80
+ import * as i7 from "primeng/radiobutton";
81
+ import * as i8 from "primeng/datepicker";
82
+ import * as i9 from "primeng/togglebutton";
83
+ import * as i10 from "primeng/slider";
84
+ import * as i11 from "primeng/button";
85
+ import * as i12 from "primeng/select";
86
+ export class PrimeNgFormsComponent {
87
+ fb;
88
+ cdr;
89
+ formName = input.required();
90
+ controls = input.required();
91
+ formSubmit = output();
92
+ form;
93
+ formChanges$ = new BehaviorSubject(false);
94
+ constructor(fb, cdr) {
95
+ this.fb = fb;
96
+ this.cdr = cdr;
97
+ }
98
+ ngOnInit() {
99
+ this.initializeForm();
100
+ }
101
+ initializeForm() {
102
+ const formControls = {};
103
+ this.controls().forEach((control) => {
104
+ formControls[control.name] = [
105
+ control.value ?? null,
106
+ this.getValidators(control),
107
+ ];
108
+ });
109
+ this.form = this.fb.group(formControls);
110
+ this.controls().forEach((control) => {
111
+ const formControl = this.form.get(control.name);
112
+ if (formControl) {
113
+ formControl.valueChanges.subscribe((value) => {
114
+ this.updateValidators(formControl, value);
115
+ });
116
+ }
117
+ });
118
+ this.formChanges$.subscribe(() => this.cdr.markForCheck());
119
+ }
120
+ getValidators(control) {
121
+ const validators = [];
122
+ if (control.validators) {
123
+ control.validators.forEach((validator) => {
124
+ if (validator.required)
125
+ validators.push(Validators.required);
126
+ if (validator.minlength)
127
+ validators.push(Validators.minLength(validator.minlength));
128
+ if (validator.maxlength)
129
+ validators.push(Validators.maxLength(validator.maxlength));
130
+ if (validator.pattern)
131
+ validators.push(Validators.pattern(validator.pattern));
132
+ if (validator.email)
133
+ validators.push(Validators.email);
134
+ if (validator.custom)
135
+ validators.push(validator.custom);
136
+ });
137
+ }
138
+ return validators;
139
+ }
140
+ updateValidators(control, value) {
141
+ if (this.shouldRequireValidation(value)) {
142
+ control.addValidators(Validators.required);
143
+ }
144
+ else {
145
+ control.removeValidators(Validators.required);
146
+ }
147
+ control.updateValueAndValidity();
148
+ this.formChanges$.next(true);
149
+ }
150
+ shouldRequireValidation(value) {
151
+ return value !== null && value !== '';
152
+ }
153
+ onFileSelect(event, controlName) {
154
+ const file = event.files[0]; // Getting the first selected file
155
+ if (file) {
156
+ console.log(`Selected file for ${controlName}:`, file);
157
+ console.log(this.form.get(controlName)?.value);
158
+ this.form.get(controlName)?.setValue(file);
159
+ console.log(this.form.get(controlName)?.value);
160
+ this.form.get(controlName)?.updateValueAndValidity(); // Update the form control's validity
161
+ // Emit the onUpload event if defined
162
+ const controlConfig = this.controls().find(control => control.name === controlName);
163
+ if (controlConfig?.events?.onUpload) {
164
+ controlConfig.events.onUpload(event);
165
+ }
166
+ }
167
+ }
168
+ onSubmit() {
169
+ this.form.markAllAsTouched();
170
+ this.form.markAsDirty();
171
+ this.form.updateValueAndValidity();
172
+ if (this.form.valid) {
173
+ this.formSubmit.emit(this.form.value);
174
+ this.form.reset();
175
+ // Clear the file input
176
+ const fileInput = document.querySelector('input[type="file"]');
177
+ if (fileInput) {
178
+ fileInput.value = '';
179
+ }
180
+ }
181
+ else {
182
+ console.error('Form Invalid');
183
+ }
184
+ this.formChanges$.next(true);
185
+ }
186
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PrimeNgFormsComponent, deps: [{ token: i1.FormBuilder }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
187
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: PrimeNgFormsComponent, isStandalone: true, selector: "primeng-forms", inputs: { formName: { classPropertyName: "formName", publicName: "formName", isSignal: true, isRequired: true, transformFunction: null }, controls: { classPropertyName: "controls", publicName: "controls", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { formSubmit: "formSubmit" }, ngImport: i0, template: "<form [formGroup]=\"form\" [attr.name]=\"formName()\" (ngSubmit)=\"onSubmit()\">\n @for (control of controls(); track $index) {\n @if (control.uiFramework === \"primeng\" || !control.uiFramework) {\n @if (form.get(control.name)) {\n <section [ngClass]=\"control.class\" [ngStyle]=\"control.style\">\n @if (control.label) {\n <label\n [attr.for]=\"control.name\"\n [ngClass]=\"control.labelClass\"\n [ngStyle]=\"control.labelStyle\"\n >\n {{ control.label }}\n </label>\n }\n\n @switch (control.type) {\n @case (\"text\") {\n <input\n pInputText\n [formControlName]=\"control.name\"\n [id]=\"control.name\"\n (change)=\"control.events?.onChange?.($event)\"\n (focus)=\"control.events?.onFocus?.($event)\"\n (blur)=\"control.events?.onBlur?.($event)\"\n (keyup)=\"control.events?.onKeyUp?.($event)\"\n (keydown)=\"control.events?.onKeyDown?.($event)\"\n (paste)=\"control.events?.onPaste?.($event)\"\n />\n }\n @case (\"number\") {\n <input\n pInputText\n type=\"number\"\n [formControlName]=\"control.name\"\n [id]=\"control.name\"\n (change)=\"control.events?.onChange?.($event)\"\n (focus)=\"control.events?.onFocus?.($event)\"\n (blur)=\"control.events?.onBlur?.($event)\"\n (keyup)=\"control.events?.onKeyUp?.($event)\"\n (keydown)=\"control.events?.onKeyDown?.($event)\"\n (paste)=\"control.events?.onPaste?.($event)\"\n />\n }\n @case (\"password\") {\n <input\n pInputText\n type=\"password\"\n [formControlName]=\"control.name\"\n [id]=\"control.name\"\n (change)=\"control.events?.onChange?.($event)\"\n (focus)=\"control.events?.onFocus?.($event)\"\n (blur)=\"control.events?.onBlur?.($event)\"\n (keyup)=\"control.events?.onKeyUp?.($event)\"\n (keydown)=\"control.events?.onKeyDown?.($event)\"\n (paste)=\"control.events?.onPaste?.($event)\"\n />\n }\n @case (\"email\") {\n <input\n pInputText\n type=\"email\"\n [formControlName]=\"control.name\"\n [id]=\"control.name\"\n (change)=\"control.events?.onChange?.($event)\"\n (focus)=\"control.events?.onFocus?.($event)\"\n (blur)=\"control.events?.onBlur?.($event)\"\n (keyup)=\"control.events?.onKeyUp?.($event)\"\n (keydown)=\"control.events?.onKeyDown?.($event)\"\n (paste)=\"control.events?.onPaste?.($event)\"\n />\n }\n @case (\"select\") {\n <p-select\n [options]=\"control.options\"\n [formControlName]=\"control.name\"\n (onChange)=\"control.events?.onChange?.($event)\"\n (onFocus)=\"control.events?.onFocus?.($event)\"\n (onBlur)=\"control.events?.onBlur?.($event)\"\n />\n }\n @case (\"multi-select\") {\n <p-multiSelect\n [options]=\"control.options\"\n [formControlName]=\"control.name\"\n (onChange)=\"control.events?.onChange?.($event)\"\n (onFocus)=\"control.events?.onFocus?.($event)\"\n (onBlur)=\"control.events?.onBlur?.($event)\"\n ></p-multiSelect>\n }\n @case (\"textarea\") {\n <textarea\n pTextarea\n [formControlName]=\"control.name\"\n [id]=\"control.name\"\n (change)=\"control.events?.onChange?.($event)\"\n (focus)=\"control.events?.onFocus?.($event)\"\n (blur)=\"control.events?.onBlur?.($event)\"\n (keyup)=\"control.events?.onKeyUp?.($event)\"\n (keydown)=\"control.events?.onKeyDown?.($event)\"\n (paste)=\"control.events?.onPaste?.($event)\"\n ></textarea>\n }\n @case (\"checkbox\") {\n <p-checkbox\n [binary]=\"true\"\n [formControlName]=\"control.name\"\n (onChange)=\"control.events?.onChange?.($event)\"\n (onFocus)=\"control.events?.onFocus?.($event)\"\n (onBlur)=\"control.events?.onBlur?.($event)\"\n ></p-checkbox>\n }\n @case (\"radio\") {\n @for (option of control.options ?? []; track $index) {\n <div>\n <p-radioButton\n [name]=\"control.name\"\n [formControlName]=\"control.name\"\n [value]=\"option\"\n [inputId]=\"'radio-' + option\"\n (onChange)=\"control.events?.onChange?.($event)\"\n (onFocus)=\"control.events?.onFocus?.($event)\"\n (onBlur)=\"control.events?.onBlur?.($event)\"\n ></p-radioButton>\n <label [for]=\"'radio-' + option\">{{ option }}</label>\n </div>\n }\n }\n @case (\"date\") {\n <p-datepicker\n [formControlName]=\"control.name\"\n (onSelect)=\"control.events?.onSelect?.($event)\"\n (onFocus)=\"control.events?.onFocus?.($event)\"\n (onBlur)=\"control.events?.onBlur?.($event)\"\n />\n }\n @case (\"toggle\") {\n <p-toggleButton\n [formControlName]=\"control.name\"\n (onChange)=\"control.events?.onChange?.($event)\"\n (onFocus)=\"control.events?.onFocus?.($event)\"\n (onBlur)=\"control.events?.onBlur?.($event)\"\n ></p-toggleButton>\n }\n <!-- @case (\"file\") {\n <p-fileUpload \n [customUpload]=\"true\"\n [formControlName]=\"control.name\"\n (onSelect)=\"control.events?.onSelect?.($event)\"\n (onClear)=\"control.events?.onClear?.($event)\"\n (onRemove)=\"control.events?.onRemove?.($event)\"\n (onError)=\"control.events?.onError?.($event)\"\n (onBeforeUpload)=\"control.events?.onBeforeUpload?.($event)\"\n (onProgress)=\"control.events?.onProgress?.($event)\"\n (onUpload)=\"control.events?.onUpload?.($event)\"\n >\n\n <p-fileUpload\n [customUpload]=\"true\"\n (onUpload)=\"onFileSelect($event, control.name)\"\n [formControlName]=\"control.name\"\n [id]=\"control.name\"\n [chooseLabel]=\"control.primeng?.chooseLabel\"\n [uploadLabel]=\"control.primeng?.uploadLabel\"\n [cancelLabel]=\"control.primeng?.cancelLabel\"\n [auto]=\"control.primeng?.auto\"\n [url]=\"control.primeng?.url\"\n [withCredentials]=\"control.primeng?.withCredentials\"\n [multiple]=\"control.primeng?.multiple\"\n [maxFileSize]=\"control.primeng?.maxFileSize\"\n [customUpload]=\"control.primeng?.customUpload\"\n [showUploadButton]=\"control.primeng?.showUploadButton\"\n [showCancelButton]=\"control.primeng?.showCancelButton\"\n [accept]=\"control.primeng?.accept\"\n [mode]=\"control.primeng?.mode\"\n [previewWidth]=\"control.primeng?.previewWidth\"\n (onSelect)=\"control.events?.onSelect?.($event)\"\n (onClear)=\"control.events?.onClear?.($event)\"\n (onRemove)=\"control.events?.onRemove?.($event)\"\n (onError)=\"control.events?.onError?.($event)\"\n (onBeforeUpload)=\"control.events?.onBeforeUpload?.($event)\"\n (onProgress)=\"control.events?.onProgress?.($event)\"\n (onUpload)=\"control.events?.onUpload?.($event)\"\n >\n <ng-template pTemplate=\"content\">\n <p-button label=\"Choose File\" icon=\"pi pi-upload\"></p-button>\n </ng-template>\n </p-fileUpload>\n } -->\n @case (\"slider\") {\n <p-slider\n [formControlName]=\"control.name\"\n (onChange)=\"control.events?.onChange?.($event)\"\n (onSlideEnd)=\"control.events?.onSlideEnd?.($event)\"\n ></p-slider>\n }\n }\n\n <validation-messages\n [control]=\"form.get(control.name)\"\n [controlName]=\"control.name\"\n [config]=\"control\"\n ></validation-messages>\n </section>\n }\n }\n }\n <button\n pButton\n type=\"submit\"\n [disabled]=\"form.invalid\"\n label=\"Submit\"\n ></button>\n</form>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.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: i1.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: ValidationMessagesComponent, selector: "validation-messages", inputs: ["control", "controlName", "config"] }, { kind: "ngmodule", type: InputTextModule }, { kind: "directive", type: i3.InputText, selector: "[pInputText]", inputs: ["variant", "fluid", "pSize"] }, { kind: "ngmodule", type: MultiSelectModule }, { kind: "component", type: i4.MultiSelect, selector: "p-multiSelect, p-multiselect, p-multi-select", inputs: ["id", "ariaLabel", "style", "styleClass", "panelStyle", "panelStyleClass", "inputId", "disabled", "fluid", "readonly", "group", "filter", "filterPlaceHolder", "filterLocale", "overlayVisible", "tabindex", "variant", "appendTo", "dataKey", "name", "ariaLabelledBy", "displaySelectedLabel", "maxSelectedLabels", "selectionLimit", "selectedItemsLabel", "showToggleAll", "emptyFilterMessage", "emptyMessage", "resetFilterOnHide", "dropdownIcon", "chipIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "showHeader", "filterBy", "scrollHeight", "lazy", "virtualScroll", "loading", "virtualScrollItemSize", "loadingIcon", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "display", "autocomplete", "size", "showClear", "autofocus", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "defaultLabel", "placeholder", "options", "filterValue", "itemSize", "selectAll", "focusOnHover", "filterFields", "selectOnFocus", "autoOptionFocus"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onClear", "onPanelShow", "onPanelHide", "onLazyLoad", "onRemove", "onSelectAllChange"] }, { kind: "ngmodule", type: TextareaModule }, { kind: "directive", type: i5.Textarea, selector: "[pTextarea]", inputs: ["autoResize", "variant", "fluid", "pSize"], outputs: ["onResize"] }, { kind: "ngmodule", type: CheckboxModule }, { kind: "component", type: i6.Checkbox, selector: "p-checkbox, p-checkBox, p-check-box", inputs: ["value", "name", "disabled", "binary", "ariaLabelledBy", "ariaLabel", "tabindex", "inputId", "style", "inputStyle", "styleClass", "inputClass", "indeterminate", "size", "formControl", "checkboxIcon", "readonly", "required", "autofocus", "trueValue", "falseValue", "variant"], outputs: ["onChange", "onFocus", "onBlur"] }, { kind: "ngmodule", type: RadioButtonModule }, { kind: "component", type: i7.RadioButton, selector: "p-radioButton, p-radiobutton, p-radio-button", inputs: ["value", "formControlName", "name", "disabled", "variant", "size", "tabindex", "inputId", "ariaLabelledBy", "ariaLabel", "style", "styleClass", "autofocus", "binary"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "ngmodule", type: DatePickerModule }, { kind: "component", type: i8.DatePicker, selector: "p-datePicker, p-datepicker, p-date-picker", inputs: ["iconDisplay", "style", "styleClass", "inputStyle", "inputId", "name", "inputStyleClass", "placeholder", "ariaLabelledBy", "ariaLabel", "iconAriaLabel", "disabled", "dateFormat", "multipleSeparator", "rangeSeparator", "inline", "showOtherMonths", "selectOtherMonths", "showIcon", "fluid", "icon", "appendTo", "readonlyInput", "shortYearCutoff", "monthNavigator", "yearNavigator", "hourFormat", "timeOnly", "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", "size", "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"] }, { kind: "ngmodule", type: ToggleButtonModule }, { kind: "component", type: i9.ToggleButton, selector: "p-toggleButton, p-togglebutton, p-toggle-button", inputs: ["onLabel", "offLabel", "onIcon", "offIcon", "ariaLabel", "ariaLabelledBy", "disabled", "style", "styleClass", "inputId", "tabindex", "size", "iconPos", "autofocus", "allowEmpty"], outputs: ["onChange"] }, { kind: "ngmodule", type: FileUploadModule }, { kind: "ngmodule", type: SliderModule }, { kind: "component", type: i10.Slider, selector: "p-slider", inputs: ["animate", "disabled", "min", "max", "orientation", "step", "range", "style", "styleClass", "ariaLabel", "ariaLabelledBy", "tabindex", "autofocus"], outputs: ["onChange", "onSlideEnd"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "directive", type: i11.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "loading", "severity", "raised", "rounded", "text", "outlined", "size", "plain", "fluid", "label", "icon", "buttonProps"] }, { kind: "ngmodule", type: SelectModule }, { kind: "component", type: i12.Select, selector: "p-select", inputs: ["id", "scrollHeight", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "loadingIcon", "filterPlaceholder", "filterLocale", "variant", "inputId", "dataKey", "filterBy", "filterFields", "autofocus", "resetFilterOnHide", "checkmark", "dropdownIcon", "loading", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "autoDisplayFirst", "group", "showClear", "emptyFilterMessage", "emptyMessage", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "size", "overlayOptions", "ariaFilterLabel", "ariaLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "focusOnHover", "selectOnFocus", "autoOptionFocus", "autofocusFilter", "fluid", "disabled", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "filterValue", "options"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear", "onLazyLoad"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
188
+ }
189
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PrimeNgFormsComponent, decorators: [{
190
+ type: Component,
191
+ args: [{ selector: 'primeng-forms', standalone: true, imports: [
192
+ CommonModule,
193
+ FormsModule,
194
+ ReactiveFormsModule,
195
+ ValidationMessagesComponent,
196
+ InputTextModule,
197
+ MultiSelectModule,
198
+ TextareaModule,
199
+ CheckboxModule,
200
+ RadioButtonModule,
201
+ DatePickerModule,
202
+ ToggleButtonModule,
203
+ FileUploadModule,
204
+ SliderModule,
205
+ ButtonModule,
206
+ SelectModule,
207
+ FileUploadValueAccessor
208
+ ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<form [formGroup]=\"form\" [attr.name]=\"formName()\" (ngSubmit)=\"onSubmit()\">\n @for (control of controls(); track $index) {\n @if (control.uiFramework === \"primeng\" || !control.uiFramework) {\n @if (form.get(control.name)) {\n <section [ngClass]=\"control.class\" [ngStyle]=\"control.style\">\n @if (control.label) {\n <label\n [attr.for]=\"control.name\"\n [ngClass]=\"control.labelClass\"\n [ngStyle]=\"control.labelStyle\"\n >\n {{ control.label }}\n </label>\n }\n\n @switch (control.type) {\n @case (\"text\") {\n <input\n pInputText\n [formControlName]=\"control.name\"\n [id]=\"control.name\"\n (change)=\"control.events?.onChange?.($event)\"\n (focus)=\"control.events?.onFocus?.($event)\"\n (blur)=\"control.events?.onBlur?.($event)\"\n (keyup)=\"control.events?.onKeyUp?.($event)\"\n (keydown)=\"control.events?.onKeyDown?.($event)\"\n (paste)=\"control.events?.onPaste?.($event)\"\n />\n }\n @case (\"number\") {\n <input\n pInputText\n type=\"number\"\n [formControlName]=\"control.name\"\n [id]=\"control.name\"\n (change)=\"control.events?.onChange?.($event)\"\n (focus)=\"control.events?.onFocus?.($event)\"\n (blur)=\"control.events?.onBlur?.($event)\"\n (keyup)=\"control.events?.onKeyUp?.($event)\"\n (keydown)=\"control.events?.onKeyDown?.($event)\"\n (paste)=\"control.events?.onPaste?.($event)\"\n />\n }\n @case (\"password\") {\n <input\n pInputText\n type=\"password\"\n [formControlName]=\"control.name\"\n [id]=\"control.name\"\n (change)=\"control.events?.onChange?.($event)\"\n (focus)=\"control.events?.onFocus?.($event)\"\n (blur)=\"control.events?.onBlur?.($event)\"\n (keyup)=\"control.events?.onKeyUp?.($event)\"\n (keydown)=\"control.events?.onKeyDown?.($event)\"\n (paste)=\"control.events?.onPaste?.($event)\"\n />\n }\n @case (\"email\") {\n <input\n pInputText\n type=\"email\"\n [formControlName]=\"control.name\"\n [id]=\"control.name\"\n (change)=\"control.events?.onChange?.($event)\"\n (focus)=\"control.events?.onFocus?.($event)\"\n (blur)=\"control.events?.onBlur?.($event)\"\n (keyup)=\"control.events?.onKeyUp?.($event)\"\n (keydown)=\"control.events?.onKeyDown?.($event)\"\n (paste)=\"control.events?.onPaste?.($event)\"\n />\n }\n @case (\"select\") {\n <p-select\n [options]=\"control.options\"\n [formControlName]=\"control.name\"\n (onChange)=\"control.events?.onChange?.($event)\"\n (onFocus)=\"control.events?.onFocus?.($event)\"\n (onBlur)=\"control.events?.onBlur?.($event)\"\n />\n }\n @case (\"multi-select\") {\n <p-multiSelect\n [options]=\"control.options\"\n [formControlName]=\"control.name\"\n (onChange)=\"control.events?.onChange?.($event)\"\n (onFocus)=\"control.events?.onFocus?.($event)\"\n (onBlur)=\"control.events?.onBlur?.($event)\"\n ></p-multiSelect>\n }\n @case (\"textarea\") {\n <textarea\n pTextarea\n [formControlName]=\"control.name\"\n [id]=\"control.name\"\n (change)=\"control.events?.onChange?.($event)\"\n (focus)=\"control.events?.onFocus?.($event)\"\n (blur)=\"control.events?.onBlur?.($event)\"\n (keyup)=\"control.events?.onKeyUp?.($event)\"\n (keydown)=\"control.events?.onKeyDown?.($event)\"\n (paste)=\"control.events?.onPaste?.($event)\"\n ></textarea>\n }\n @case (\"checkbox\") {\n <p-checkbox\n [binary]=\"true\"\n [formControlName]=\"control.name\"\n (onChange)=\"control.events?.onChange?.($event)\"\n (onFocus)=\"control.events?.onFocus?.($event)\"\n (onBlur)=\"control.events?.onBlur?.($event)\"\n ></p-checkbox>\n }\n @case (\"radio\") {\n @for (option of control.options ?? []; track $index) {\n <div>\n <p-radioButton\n [name]=\"control.name\"\n [formControlName]=\"control.name\"\n [value]=\"option\"\n [inputId]=\"'radio-' + option\"\n (onChange)=\"control.events?.onChange?.($event)\"\n (onFocus)=\"control.events?.onFocus?.($event)\"\n (onBlur)=\"control.events?.onBlur?.($event)\"\n ></p-radioButton>\n <label [for]=\"'radio-' + option\">{{ option }}</label>\n </div>\n }\n }\n @case (\"date\") {\n <p-datepicker\n [formControlName]=\"control.name\"\n (onSelect)=\"control.events?.onSelect?.($event)\"\n (onFocus)=\"control.events?.onFocus?.($event)\"\n (onBlur)=\"control.events?.onBlur?.($event)\"\n />\n }\n @case (\"toggle\") {\n <p-toggleButton\n [formControlName]=\"control.name\"\n (onChange)=\"control.events?.onChange?.($event)\"\n (onFocus)=\"control.events?.onFocus?.($event)\"\n (onBlur)=\"control.events?.onBlur?.($event)\"\n ></p-toggleButton>\n }\n <!-- @case (\"file\") {\n <p-fileUpload \n [customUpload]=\"true\"\n [formControlName]=\"control.name\"\n (onSelect)=\"control.events?.onSelect?.($event)\"\n (onClear)=\"control.events?.onClear?.($event)\"\n (onRemove)=\"control.events?.onRemove?.($event)\"\n (onError)=\"control.events?.onError?.($event)\"\n (onBeforeUpload)=\"control.events?.onBeforeUpload?.($event)\"\n (onProgress)=\"control.events?.onProgress?.($event)\"\n (onUpload)=\"control.events?.onUpload?.($event)\"\n >\n\n <p-fileUpload\n [customUpload]=\"true\"\n (onUpload)=\"onFileSelect($event, control.name)\"\n [formControlName]=\"control.name\"\n [id]=\"control.name\"\n [chooseLabel]=\"control.primeng?.chooseLabel\"\n [uploadLabel]=\"control.primeng?.uploadLabel\"\n [cancelLabel]=\"control.primeng?.cancelLabel\"\n [auto]=\"control.primeng?.auto\"\n [url]=\"control.primeng?.url\"\n [withCredentials]=\"control.primeng?.withCredentials\"\n [multiple]=\"control.primeng?.multiple\"\n [maxFileSize]=\"control.primeng?.maxFileSize\"\n [customUpload]=\"control.primeng?.customUpload\"\n [showUploadButton]=\"control.primeng?.showUploadButton\"\n [showCancelButton]=\"control.primeng?.showCancelButton\"\n [accept]=\"control.primeng?.accept\"\n [mode]=\"control.primeng?.mode\"\n [previewWidth]=\"control.primeng?.previewWidth\"\n (onSelect)=\"control.events?.onSelect?.($event)\"\n (onClear)=\"control.events?.onClear?.($event)\"\n (onRemove)=\"control.events?.onRemove?.($event)\"\n (onError)=\"control.events?.onError?.($event)\"\n (onBeforeUpload)=\"control.events?.onBeforeUpload?.($event)\"\n (onProgress)=\"control.events?.onProgress?.($event)\"\n (onUpload)=\"control.events?.onUpload?.($event)\"\n >\n <ng-template pTemplate=\"content\">\n <p-button label=\"Choose File\" icon=\"pi pi-upload\"></p-button>\n </ng-template>\n </p-fileUpload>\n } -->\n @case (\"slider\") {\n <p-slider\n [formControlName]=\"control.name\"\n (onChange)=\"control.events?.onChange?.($event)\"\n (onSlideEnd)=\"control.events?.onSlideEnd?.($event)\"\n ></p-slider>\n }\n }\n\n <validation-messages\n [control]=\"form.get(control.name)\"\n [controlName]=\"control.name\"\n [config]=\"control\"\n ></validation-messages>\n </section>\n }\n }\n }\n <button\n pButton\n type=\"submit\"\n [disabled]=\"form.invalid\"\n label=\"Submit\"\n ></button>\n</form>\n" }]
209
+ }], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i0.ChangeDetectorRef }] });
210
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"prime-form.component.js","sourceRoot":"","sources":["../../../../../ngForm/src/app/prime-form/prime-form.component.ts","../../../../../ngForm/src/app/prime-form/prime-form.component.html"],"names":[],"mappings":"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","sourcesContent":["/**\n * PrimeNgFormsComponent is a standalone Angular component that dynamically generates\n * a form based on the provided configuration. It leverages PrimeNG UI components\n * and Angular Reactive Forms for form creation and validation.\n * \n * @selector primeng-forms\n * @standalone true\n * @imports [\n *   CommonModule,\n *   FormsModule,\n *   ReactiveFormsModule,\n *   ValidationMessagesComponent,\n *   InputTextModule,\n *   MultiSelectModule,\n *   TextareaModule,\n *   CheckboxModule,\n *   RadioButtonModule,\n *   DatePickerModule,\n *   ToggleButtonModule,\n *   FileUploadModule,\n *   SliderModule,\n *   ButtonModule,\n *   SelectModule,\n *   FileUploadValueAccessor\n * ]\n * @templateUrl ./prime-form.component.html\n * @styleUrl ./prime-form.component.css\n * @changeDetection ChangeDetectionStrategy.OnPush\n * \n * @property {string} formName - The name of the form.\n * @property {FormControlConfig[]} controls - The configuration for the form controls.\n * @property {EventEmitter<Record<string, any>>} formSubmit - Event emitter for form submission.\n * @property {FormGroup} form - The reactive form group.\n * @property {BehaviorSubject<boolean>} formChanges$ - Observable to track form changes.\n * \n * @constructor\n * @param {FormBuilder} fb - FormBuilder service to create form controls.\n * @param {ChangeDetectorRef} cdr - ChangeDetectorRef to manually trigger change detection.\n * \n * @method ngOnInit - Lifecycle hook that initializes the form.\n * @method initializeForm - Initializes the form controls and sets up value change subscriptions.\n * @method getValidators - Returns an array of validators for a given form control configuration.\n * @param {FormControlConfig} control - The configuration for a form control.\n * @returns {ValidatorFn[]} - An array of validator functions.\n * @method updateValidators - Updates the validators for a form control based on its value.\n * @param {AbstractControl} control - The form control to update.\n * @param {any} value - The current value of the form control.\n * @method shouldRequireValidation - Determines if a form control should require validation.\n * @param {any} value - The current value of the form control.\n * @returns {boolean} - True if validation is required, false otherwise.\n * @method onFileSelect - Handles file selection for file upload controls.\n * @param {any} event - The file selection event.\n * @param {string} controlName - The name of the form control.\n * @method onSubmit - Handles form submission, validates the form, and emits the form value.\n */\nimport { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  input,\n  output,\n} from '@angular/core';\nimport {\n  ReactiveFormsModule,\n  FormsModule,\n  FormGroup,\n  FormBuilder,\n  ValidatorFn,\n  Validators,\n  AbstractControl,\n} from '@angular/forms';\nimport { ValidationMessagesComponent } from '../validation-messages/validation-messages.component';\nimport { FormControlConfig } from '../formControlConfig';\nimport { BehaviorSubject } from 'rxjs';\nimport { InputTextModule } from 'primeng/inputtext';\nimport { MultiSelectModule } from 'primeng/multiselect';\nimport { TextareaModule } from 'primeng/textarea';\nimport { CheckboxModule } from 'primeng/checkbox';\nimport { RadioButtonModule } from 'primeng/radiobutton';\nimport { ToggleButtonModule } from 'primeng/togglebutton';\nimport { FileUploadModule } from 'primeng/fileupload';\nimport { SliderModule } from 'primeng/slider';\nimport { ButtonModule } from 'primeng/button';\nimport { DatePickerModule } from 'primeng/datepicker';\nimport { SelectModule } from 'primeng/select';\nimport { FileUploadValueAccessor } from '../file-upload-accessor.directive';\n\n\n@Component({\n  selector: 'primeng-forms',\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    ValidationMessagesComponent,\n    InputTextModule,\n    MultiSelectModule,\n    TextareaModule,\n    CheckboxModule,\n    RadioButtonModule,\n    DatePickerModule,\n    ToggleButtonModule,\n    FileUploadModule,\n    SliderModule,\n    ButtonModule,\n    SelectModule,\n    FileUploadValueAccessor\n  ],\n  templateUrl: './prime-form.component.html',\n  styleUrl: './prime-form.component.css',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class PrimeNgFormsComponent {\n  formName = input.required<string>();\n  controls = input.required<FormControlConfig[]>();\n  formSubmit = output<Record<string, any>>();\n\n  form!: FormGroup;\n  private formChanges$ = new BehaviorSubject<boolean>(false);\n\n  constructor(\n    private fb: FormBuilder,\n    private cdr: ChangeDetectorRef,\n  ) {}\n\n  ngOnInit(): void {\n    this.initializeForm();\n  }\n\n  private initializeForm(): void {\n    const formControls: { [key: string]: any } = {};\n\n    this.controls().forEach((control) => {\n      formControls[control.name] = [\n        control.value ?? null,\n        this.getValidators(control),\n      ];\n    });\n\n    this.form = this.fb.group(formControls);\n\n    this.controls().forEach((control) => {\n      const formControl = this.form.get(control.name);\n      if (formControl) {\n        formControl.valueChanges.subscribe((value) => {\n          this.updateValidators(formControl, value);\n        });\n      }\n    });\n\n    this.formChanges$.subscribe(() => this.cdr.markForCheck());\n  }\n\n  private getValidators(control: FormControlConfig): ValidatorFn[] {\n    const validators: ValidatorFn[] = [];\n\n    if (control.validators) {\n      control.validators.forEach((validator) => {\n        if (validator.required) validators.push(Validators.required);\n        if (validator.minlength)\n          validators.push(Validators.minLength(validator.minlength));\n        if (validator.maxlength)\n          validators.push(Validators.maxLength(validator.maxlength));\n        if (validator.pattern)\n          validators.push(Validators.pattern(validator.pattern));\n        if (validator.email) validators.push(Validators.email);\n        if (validator.custom) validators.push(validator.custom);\n      });\n    }\n\n    return validators;\n  }\n\n  private updateValidators(control: AbstractControl, value: any): void {\n    if (this.shouldRequireValidation(value)) {\n      control.addValidators(Validators.required);\n    } else {\n      control.removeValidators(Validators.required);\n    }\n\n    control.updateValueAndValidity();\n    this.formChanges$.next(true);\n  }\n\n  private shouldRequireValidation(value: any): boolean {\n    return value !== null && value !== '';\n  }\n\n  onFileSelect(event: any, controlName: string) {\n    const file = event.files[0]; // Getting the first selected file\n    if (file) {\n      console.log(`Selected file for ${controlName}:`, file);\n      console.log(this.form.get(controlName)?.value);\n      \n      this.form.get(controlName)?.setValue(file);\n      console.log(this.form.get(controlName)?.value);\n      this.form.get(controlName)?.updateValueAndValidity(); // Update the form control's validity\n  \n      // Emit the onUpload event if defined\n      const controlConfig = this.controls().find(control => control.name === controlName);\n      if (controlConfig?.events?.onUpload) {\n        controlConfig.events.onUpload(event);\n      }\n    }\n  }\n\n  onSubmit(): void {\n    this.form.markAllAsTouched();\n    this.form.markAsDirty();\n    this.form.updateValueAndValidity();\n  \n    if (this.form.valid) {\n      this.formSubmit.emit(this.form.value);\n      this.form.reset();\n      // Clear the file input\n      const fileInput = document.querySelector('input[type=\"file\"]') as HTMLInputElement;\n      if (fileInput) {\n        fileInput.value = '';\n      }\n    } else {\n      console.error('Form Invalid');\n    }\n  \n    this.formChanges$.next(true);\n  }\n}\n","<form [formGroup]=\"form\" [attr.name]=\"formName()\" (ngSubmit)=\"onSubmit()\">\n  @for (control of controls(); track $index) {\n    @if (control.uiFramework === \"primeng\" || !control.uiFramework) {\n      @if (form.get(control.name)) {\n        <section [ngClass]=\"control.class\" [ngStyle]=\"control.style\">\n          @if (control.label) {\n            <label\n              [attr.for]=\"control.name\"\n              [ngClass]=\"control.labelClass\"\n              [ngStyle]=\"control.labelStyle\"\n            >\n              {{ control.label }}\n            </label>\n          }\n\n          @switch (control.type) {\n            @case (\"text\") {\n              <input\n                pInputText\n                [formControlName]=\"control.name\"\n                [id]=\"control.name\"\n                (change)=\"control.events?.onChange?.($event)\"\n                (focus)=\"control.events?.onFocus?.($event)\"\n                (blur)=\"control.events?.onBlur?.($event)\"\n                (keyup)=\"control.events?.onKeyUp?.($event)\"\n                (keydown)=\"control.events?.onKeyDown?.($event)\"\n                (paste)=\"control.events?.onPaste?.($event)\"\n              />\n            }\n            @case (\"number\") {\n              <input\n                pInputText\n                type=\"number\"\n                [formControlName]=\"control.name\"\n                [id]=\"control.name\"\n                (change)=\"control.events?.onChange?.($event)\"\n                (focus)=\"control.events?.onFocus?.($event)\"\n                (blur)=\"control.events?.onBlur?.($event)\"\n                (keyup)=\"control.events?.onKeyUp?.($event)\"\n                (keydown)=\"control.events?.onKeyDown?.($event)\"\n                (paste)=\"control.events?.onPaste?.($event)\"\n              />\n            }\n            @case (\"password\") {\n              <input\n                pInputText\n                type=\"password\"\n                [formControlName]=\"control.name\"\n                [id]=\"control.name\"\n                (change)=\"control.events?.onChange?.($event)\"\n                (focus)=\"control.events?.onFocus?.($event)\"\n                (blur)=\"control.events?.onBlur?.($event)\"\n                (keyup)=\"control.events?.onKeyUp?.($event)\"\n                (keydown)=\"control.events?.onKeyDown?.($event)\"\n                (paste)=\"control.events?.onPaste?.($event)\"\n              />\n            }\n            @case (\"email\") {\n              <input\n                pInputText\n                type=\"email\"\n                [formControlName]=\"control.name\"\n                [id]=\"control.name\"\n                (change)=\"control.events?.onChange?.($event)\"\n                (focus)=\"control.events?.onFocus?.($event)\"\n                (blur)=\"control.events?.onBlur?.($event)\"\n                (keyup)=\"control.events?.onKeyUp?.($event)\"\n                (keydown)=\"control.events?.onKeyDown?.($event)\"\n                (paste)=\"control.events?.onPaste?.($event)\"\n              />\n            }\n            @case (\"select\") {\n              <p-select\n                [options]=\"control.options\"\n                [formControlName]=\"control.name\"\n                (onChange)=\"control.events?.onChange?.($event)\"\n                (onFocus)=\"control.events?.onFocus?.($event)\"\n                (onBlur)=\"control.events?.onBlur?.($event)\"\n              />\n            }\n            @case (\"multi-select\") {\n              <p-multiSelect\n                [options]=\"control.options\"\n                [formControlName]=\"control.name\"\n                (onChange)=\"control.events?.onChange?.($event)\"\n                (onFocus)=\"control.events?.onFocus?.($event)\"\n                (onBlur)=\"control.events?.onBlur?.($event)\"\n              ></p-multiSelect>\n            }\n            @case (\"textarea\") {\n              <textarea\n                pTextarea\n                [formControlName]=\"control.name\"\n                [id]=\"control.name\"\n                (change)=\"control.events?.onChange?.($event)\"\n                (focus)=\"control.events?.onFocus?.($event)\"\n                (blur)=\"control.events?.onBlur?.($event)\"\n                (keyup)=\"control.events?.onKeyUp?.($event)\"\n                (keydown)=\"control.events?.onKeyDown?.($event)\"\n                (paste)=\"control.events?.onPaste?.($event)\"\n              ></textarea>\n            }\n            @case (\"checkbox\") {\n              <p-checkbox\n                [binary]=\"true\"\n                [formControlName]=\"control.name\"\n                (onChange)=\"control.events?.onChange?.($event)\"\n                (onFocus)=\"control.events?.onFocus?.($event)\"\n                (onBlur)=\"control.events?.onBlur?.($event)\"\n              ></p-checkbox>\n            }\n            @case (\"radio\") {\n              @for (option of control.options ?? []; track $index) {\n                <div>\n                  <p-radioButton\n                    [name]=\"control.name\"\n                    [formControlName]=\"control.name\"\n                    [value]=\"option\"\n                    [inputId]=\"'radio-' + option\"\n                    (onChange)=\"control.events?.onChange?.($event)\"\n                    (onFocus)=\"control.events?.onFocus?.($event)\"\n                    (onBlur)=\"control.events?.onBlur?.($event)\"\n                  ></p-radioButton>\n                  <label [for]=\"'radio-' + option\">{{ option }}</label>\n                </div>\n              }\n            }\n            @case (\"date\") {\n              <p-datepicker\n                [formControlName]=\"control.name\"\n                (onSelect)=\"control.events?.onSelect?.($event)\"\n                (onFocus)=\"control.events?.onFocus?.($event)\"\n                (onBlur)=\"control.events?.onBlur?.($event)\"\n              />\n            }\n            @case (\"toggle\") {\n              <p-toggleButton\n                [formControlName]=\"control.name\"\n                (onChange)=\"control.events?.onChange?.($event)\"\n                (onFocus)=\"control.events?.onFocus?.($event)\"\n                (onBlur)=\"control.events?.onBlur?.($event)\"\n              ></p-toggleButton>\n            }\n            <!-- @case (\"file\") {\n              <p-fileUpload \n              [customUpload]=\"true\"\n              [formControlName]=\"control.name\"\n              (onSelect)=\"control.events?.onSelect?.($event)\"\n              (onClear)=\"control.events?.onClear?.($event)\"\n              (onRemove)=\"control.events?.onRemove?.($event)\"\n              (onError)=\"control.events?.onError?.($event)\"\n              (onBeforeUpload)=\"control.events?.onBeforeUpload?.($event)\"\n              (onProgress)=\"control.events?.onProgress?.($event)\"\n              (onUpload)=\"control.events?.onUpload?.($event)\"\n              >\n\n              <p-fileUpload\n                [customUpload]=\"true\"\n                (onUpload)=\"onFileSelect($event, control.name)\"\n                [formControlName]=\"control.name\"\n                [id]=\"control.name\"\n                [chooseLabel]=\"control.primeng?.chooseLabel\"\n                [uploadLabel]=\"control.primeng?.uploadLabel\"\n                [cancelLabel]=\"control.primeng?.cancelLabel\"\n                [auto]=\"control.primeng?.auto\"\n                [url]=\"control.primeng?.url\"\n                [withCredentials]=\"control.primeng?.withCredentials\"\n                [multiple]=\"control.primeng?.multiple\"\n                [maxFileSize]=\"control.primeng?.maxFileSize\"\n                [customUpload]=\"control.primeng?.customUpload\"\n                [showUploadButton]=\"control.primeng?.showUploadButton\"\n                [showCancelButton]=\"control.primeng?.showCancelButton\"\n                [accept]=\"control.primeng?.accept\"\n                [mode]=\"control.primeng?.mode\"\n                [previewWidth]=\"control.primeng?.previewWidth\"\n                (onSelect)=\"control.events?.onSelect?.($event)\"\n                (onClear)=\"control.events?.onClear?.($event)\"\n                (onRemove)=\"control.events?.onRemove?.($event)\"\n                (onError)=\"control.events?.onError?.($event)\"\n                (onBeforeUpload)=\"control.events?.onBeforeUpload?.($event)\"\n                (onProgress)=\"control.events?.onProgress?.($event)\"\n                (onUpload)=\"control.events?.onUpload?.($event)\"\n              >\n                <ng-template pTemplate=\"content\">\n                  <p-button label=\"Choose File\" icon=\"pi pi-upload\"></p-button>\n                </ng-template>\n              </p-fileUpload>\n            } -->\n            @case (\"slider\") {\n              <p-slider\n                [formControlName]=\"control.name\"\n                (onChange)=\"control.events?.onChange?.($event)\"\n                (onSlideEnd)=\"control.events?.onSlideEnd?.($event)\"\n              ></p-slider>\n            }\n          }\n\n          <validation-messages\n            [control]=\"form.get(control.name)\"\n            [controlName]=\"control.name\"\n            [config]=\"control\"\n          ></validation-messages>\n        </section>\n      }\n    }\n  }\n  <button\n    pButton\n    type=\"submit\"\n    [disabled]=\"form.invalid\"\n    label=\"Submit\"\n  ></button>\n</form>\n"]}
@@ -0,0 +1,29 @@
1
+ import { Component, Input } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class ValidationMessagesComponent {
4
+ control; // The form control to validate
5
+ controlName; // The name of the control (for displaying in messages)
6
+ config; // The configuration for the control
7
+ getValidatorValue(validatorName, key) {
8
+ return this.control?.errors?.[validatorName]?.[key];
9
+ }
10
+ getCustomErrorMessage() {
11
+ if (this.control?.errors?.['custom']) {
12
+ return this.control.errors['custom'].message ?? 'Invalid input';
13
+ }
14
+ return null;
15
+ }
16
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ValidationMessagesComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
17
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ValidationMessagesComponent, isStandalone: true, selector: "validation-messages", inputs: { control: "control", controlName: "controlName", config: "config" }, ngImport: i0, template: "@if (control?.invalid && control?.touched) {\n <section class=\"error-messages\" style=\"color: red\">\n @if (control?.errors?.[\"required\"]) {\n <small>{{ controlName }} is required</small>\n }\n @if (control?.errors?.[\"minlength\"]) {\n <small\n >Minimum length:\n {{ getValidatorValue(\"minlength\", \"requiredLength\") }}</small\n >\n }\n @if (control?.errors?.[\"maxlength\"]) {\n <small\n >Maximum length:\n {{ getValidatorValue(\"maxlength\", \"requiredLength\") }}</small\n >\n }\n @if (control?.errors?.[\"pattern\"]) {\n <small>Invalid format</small>\n }\n @if (control?.errors?.[\"email\"]) {\n <small>Invalid email address</small>\n }\n @if (control?.errors?.[\"min\"]) {\n <small\n >Value must be at least {{ getValidatorValue(\"min\", \"min\") }}</small\n >\n }\n @if (control?.errors?.[\"max\"]) {\n <small>Value must not exceed {{ getValidatorValue(\"max\", \"max\") }}</small>\n }\n @if (control?.errors?.[\"custom\"]) {\n <small>{{ getCustomErrorMessage() }}</small>\n }\n </section>\n}\n", styles: [""] });
18
+ }
19
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ValidationMessagesComponent, decorators: [{
20
+ type: Component,
21
+ args: [{ selector: 'validation-messages', standalone: true, imports: [], template: "@if (control?.invalid && control?.touched) {\n <section class=\"error-messages\" style=\"color: red\">\n @if (control?.errors?.[\"required\"]) {\n <small>{{ controlName }} is required</small>\n }\n @if (control?.errors?.[\"minlength\"]) {\n <small\n >Minimum length:\n {{ getValidatorValue(\"minlength\", \"requiredLength\") }}</small\n >\n }\n @if (control?.errors?.[\"maxlength\"]) {\n <small\n >Maximum length:\n {{ getValidatorValue(\"maxlength\", \"requiredLength\") }}</small\n >\n }\n @if (control?.errors?.[\"pattern\"]) {\n <small>Invalid format</small>\n }\n @if (control?.errors?.[\"email\"]) {\n <small>Invalid email address</small>\n }\n @if (control?.errors?.[\"min\"]) {\n <small\n >Value must be at least {{ getValidatorValue(\"min\", \"min\") }}</small\n >\n }\n @if (control?.errors?.[\"max\"]) {\n <small>Value must not exceed {{ getValidatorValue(\"max\", \"max\") }}</small>\n }\n @if (control?.errors?.[\"custom\"]) {\n <small>{{ getCustomErrorMessage() }}</small>\n }\n </section>\n}\n" }]
22
+ }], propDecorators: { control: [{
23
+ type: Input
24
+ }], controlName: [{
25
+ type: Input
26
+ }], config: [{
27
+ type: Input
28
+ }] } });
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGlvbi1tZXNzYWdlcy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9uZ0Zvcm0vc3JjL2FwcC92YWxpZGF0aW9uLW1lc3NhZ2VzL3ZhbGlkYXRpb24tbWVzc2FnZXMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vbmdGb3JtL3NyYy9hcHAvdmFsaWRhdGlvbi1tZXNzYWdlcy92YWxpZGF0aW9uLW1lc3NhZ2VzLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQVdqRCxNQUFNLE9BQU8sMkJBQTJCO0lBQzdCLE9BQU8sQ0FBMEIsQ0FBQywrQkFBK0I7SUFDakUsV0FBVyxDQUFVLENBQUMsdURBQXVEO0lBQzdFLE1BQU0sQ0FBcUIsQ0FBQyxvQ0FBb0M7SUFFekUsaUJBQWlCLENBQUMsYUFBcUMsRUFBRSxHQUFXO1FBQ2xFLE9BQU8sSUFBSSxDQUFDLE9BQU8sRUFBRSxNQUFNLEVBQUUsQ0FBQyxhQUFhLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3RELENBQUM7SUFFRCxxQkFBcUI7UUFDbkIsSUFBSSxJQUFJLENBQUMsT0FBTyxFQUFFLE1BQU0sRUFBRSxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUM7WUFDckMsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQyxPQUFPLElBQUksZUFBZSxDQUFDO1FBQ2xFLENBQUM7UUFDRCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7d0dBZFUsMkJBQTJCOzRGQUEzQiwyQkFBMkIsNkpDWHhDLDhuQ0FvQ0E7OzRGRHpCYSwyQkFBMkI7a0JBUHZDLFNBQVM7K0JBQ0UscUJBQXFCLGNBQ25CLElBQUksV0FDUCxFQUFFOzhCQUtGLE9BQU87c0JBQWYsS0FBSztnQkFDRyxXQUFXO3NCQUFuQixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFic3RyYWN0Q29udHJvbCwgVmFsaWRhdGlvbkVycm9ycyB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IEZvcm1Db250cm9sQ29uZmlnIH0gZnJvbSAnLi4vZm9ybUNvbnRyb2xDb25maWcnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd2YWxpZGF0aW9uLW1lc3NhZ2VzJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW10sXG4gIHRlbXBsYXRlVXJsOiAnLi92YWxpZGF0aW9uLW1lc3NhZ2VzLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmw6ICcuL3ZhbGlkYXRpb24tbWVzc2FnZXMuY29tcG9uZW50LmNzcycsXG59KVxuZXhwb3J0IGNsYXNzIFZhbGlkYXRpb25NZXNzYWdlc0NvbXBvbmVudCB7XG4gIEBJbnB1dCgpIGNvbnRyb2whOiBBYnN0cmFjdENvbnRyb2wgfCBudWxsOyAvLyBUaGUgZm9ybSBjb250cm9sIHRvIHZhbGlkYXRlXG4gIEBJbnB1dCgpIGNvbnRyb2xOYW1lITogc3RyaW5nOyAvLyBUaGUgbmFtZSBvZiB0aGUgY29udHJvbCAoZm9yIGRpc3BsYXlpbmcgaW4gbWVzc2FnZXMpXG4gIEBJbnB1dCgpIGNvbmZpZyE6IEZvcm1Db250cm9sQ29uZmlnOyAvLyBUaGUgY29uZmlndXJhdGlvbiBmb3IgdGhlIGNvbnRyb2xcblxuICBnZXRWYWxpZGF0b3JWYWx1ZSh2YWxpZGF0b3JOYW1lOiBrZXlvZiBWYWxpZGF0aW9uRXJyb3JzLCBrZXk6IHN0cmluZyk6IGFueSB7XG4gICAgcmV0dXJuIHRoaXMuY29udHJvbD8uZXJyb3JzPy5bdmFsaWRhdG9yTmFtZV0/LltrZXldO1xuICB9XG5cbiAgZ2V0Q3VzdG9tRXJyb3JNZXNzYWdlKCk6IHN0cmluZyB8IG51bGwge1xuICAgIGlmICh0aGlzLmNvbnRyb2w/LmVycm9ycz8uWydjdXN0b20nXSkge1xuICAgICAgcmV0dXJuIHRoaXMuY29udHJvbC5lcnJvcnNbJ2N1c3RvbSddLm1lc3NhZ2UgPz8gJ0ludmFsaWQgaW5wdXQnO1xuICAgIH1cbiAgICByZXR1cm4gbnVsbDtcbiAgfVxufVxuIiwiQGlmIChjb250cm9sPy5pbnZhbGlkICYmIGNvbnRyb2w/LnRvdWNoZWQpIHtcbiAgPHNlY3Rpb24gY2xhc3M9XCJlcnJvci1tZXNzYWdlc1wiIHN0eWxlPVwiY29sb3I6IHJlZFwiPlxuICAgIEBpZiAoY29udHJvbD8uZXJyb3JzPy5bXCJyZXF1aXJlZFwiXSkge1xuICAgICAgPHNtYWxsPnt7IGNvbnRyb2xOYW1lIH19IGlzIHJlcXVpcmVkPC9zbWFsbD5cbiAgICB9XG4gICAgQGlmIChjb250cm9sPy5lcnJvcnM/LltcIm1pbmxlbmd0aFwiXSkge1xuICAgICAgPHNtYWxsXG4gICAgICAgID5NaW5pbXVtIGxlbmd0aDpcbiAgICAgICAge3sgZ2V0VmFsaWRhdG9yVmFsdWUoXCJtaW5sZW5ndGhcIiwgXCJyZXF1aXJlZExlbmd0aFwiKSB9fTwvc21hbGxcbiAgICAgID5cbiAgICB9XG4gICAgQGlmIChjb250cm9sPy5lcnJvcnM/LltcIm1heGxlbmd0aFwiXSkge1xuICAgICAgPHNtYWxsXG4gICAgICAgID5NYXhpbXVtIGxlbmd0aDpcbiAgICAgICAge3sgZ2V0VmFsaWRhdG9yVmFsdWUoXCJtYXhsZW5ndGhcIiwgXCJyZXF1aXJlZExlbmd0aFwiKSB9fTwvc21hbGxcbiAgICAgID5cbiAgICB9XG4gICAgQGlmIChjb250cm9sPy5lcnJvcnM/LltcInBhdHRlcm5cIl0pIHtcbiAgICAgIDxzbWFsbD5JbnZhbGlkIGZvcm1hdDwvc21hbGw+XG4gICAgfVxuICAgIEBpZiAoY29udHJvbD8uZXJyb3JzPy5bXCJlbWFpbFwiXSkge1xuICAgICAgPHNtYWxsPkludmFsaWQgZW1haWwgYWRkcmVzczwvc21hbGw+XG4gICAgfVxuICAgIEBpZiAoY29udHJvbD8uZXJyb3JzPy5bXCJtaW5cIl0pIHtcbiAgICAgIDxzbWFsbFxuICAgICAgICA+VmFsdWUgbXVzdCBiZSBhdCBsZWFzdCB7eyBnZXRWYWxpZGF0b3JWYWx1ZShcIm1pblwiLCBcIm1pblwiKSB9fTwvc21hbGxcbiAgICAgID5cbiAgICB9XG4gICAgQGlmIChjb250cm9sPy5lcnJvcnM/LltcIm1heFwiXSkge1xuICAgICAgPHNtYWxsPlZhbHVlIG11c3Qgbm90IGV4Y2VlZCB7eyBnZXRWYWxpZGF0b3JWYWx1ZShcIm1heFwiLCBcIm1heFwiKSB9fTwvc21hbGw+XG4gICAgfVxuICAgIEBpZiAoY29udHJvbD8uZXJyb3JzPy5bXCJjdXN0b21cIl0pIHtcbiAgICAgIDxzbWFsbD57eyBnZXRDdXN0b21FcnJvck1lc3NhZ2UoKSB9fTwvc21hbGw+XG4gICAgfVxuICA8L3NlY3Rpb24+XG59XG4iXX0=
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public-api';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnNhY2hyZWYtbmctZm9ybS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL25nRm9ybS9zcmMvYnNhY2hyZWYtbmctZm9ybS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpYy1hcGknO1xuIl19
@@ -0,0 +1,5 @@
1
+ export * from './app/default-forms/default-forms.component';
2
+ export * from './app/formControlConfig';
3
+ export * from './app/material-form/material-form.component';
4
+ export * from './app/prime-form/prime-form.component';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL25nRm9ybS9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLHVDQUF1QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hcHAvZGVmYXVsdC1mb3Jtcy9kZWZhdWx0LWZvcm1zLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2FwcC9mb3JtQ29udHJvbENvbmZpZyc7XG5leHBvcnQgKiBmcm9tICcuL2FwcC9tYXRlcmlhbC1mb3JtL21hdGVyaWFsLWZvcm0uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vYXBwL3ByaW1lLWZvcm0vcHJpbWUtZm9ybS5jb21wb25lbnQnO1xuIl19