@bsachref/ng-form 1.0.3 → 1.0.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/LICENSE CHANGED
@@ -1,6 +1,6 @@
1
1
  MIT License
2
2
 
3
- Copyright (c) [2025] [BOUSNINA ACHRAF]
3
+ Copyright (c) 2025 bsachref
4
4
 
5
5
  Permission is hereby granted, free of charge, to any person obtaining a copy
6
6
  of this software and associated documentation files (the "Software"), to deal
@@ -0,0 +1,23 @@
1
+ import { ChangeDetectorRef } from '@angular/core';
2
+ import { FormGroup, FormBuilder, ValidatorFn, AbstractControl } from '@angular/forms';
3
+ import { BehaviorSubject } from 'rxjs';
4
+ import { FormControlConfig } from '../public-api';
5
+ import * as i0 from "@angular/core";
6
+ export declare class BaseFormsComponent {
7
+ protected fb: FormBuilder;
8
+ protected cdr: ChangeDetectorRef;
9
+ formName: import("@angular/core").InputSignal<string>;
10
+ controls: import("@angular/core").InputSignal<FormControlConfig[]>;
11
+ formSubmit: import("@angular/core").OutputEmitterRef<Record<string, any>>;
12
+ form: FormGroup;
13
+ protected formChanges$: BehaviorSubject<boolean>;
14
+ constructor(fb: FormBuilder, cdr: ChangeDetectorRef);
15
+ ngOnInit(): void;
16
+ protected initializeForm(): void;
17
+ protected getValidators(control: FormControlConfig): ValidatorFn[];
18
+ protected updateValidators(control: AbstractControl, value: any): void;
19
+ protected shouldRequireValidation(value: any): boolean;
20
+ onSubmit(): void;
21
+ static ɵfac: i0.ɵɵFactoryDeclaration<BaseFormsComponent, never>;
22
+ static ɵcmp: i0.ɵɵComponentDeclaration<BaseFormsComponent, "base-forms", never, { "formName": { "alias": "formName"; "required": true; "isSignal": true; }; "controls": { "alias": "controls"; "required": true; "isSignal": true; }; }, { "formSubmit": "formSubmit"; }, never, never, true, never>;
23
+ }
@@ -1,22 +1,6 @@
1
- import { ChangeDetectorRef } from '@angular/core';
2
- import { FormGroup, FormBuilder } from '@angular/forms';
3
- import { FormControlConfig } from '../formControlConfig';
1
+ import { BaseFormsComponent } from '../base.component';
4
2
  import * as i0 from "@angular/core";
5
- export declare class DefaultFormsComponent {
6
- private fb;
7
- private cdr;
8
- formName: import("@angular/core").InputSignal<string>;
9
- controls: import("@angular/core").InputSignal<FormControlConfig[]>;
10
- formSubmit: import("@angular/core").OutputEmitterRef<Record<string, any>>;
11
- form: FormGroup;
12
- private formChanges$;
13
- constructor(fb: FormBuilder, cdr: ChangeDetectorRef);
14
- ngOnInit(): void;
15
- private initializeForm;
16
- private getValidators;
17
- private updateValidators;
18
- private shouldRequireValidation;
19
- onSubmit(): void;
3
+ export declare class DefaultFormsComponent extends BaseFormsComponent {
20
4
  static ɵfac: i0.ɵɵFactoryDeclaration<DefaultFormsComponent, never>;
21
- static ɵcmp: i0.ɵɵComponentDeclaration<DefaultFormsComponent, "default-forms", never, { "formName": { "alias": "formName"; "required": true; "isSignal": true; }; "controls": { "alias": "controls"; "required": true; "isSignal": true; }; }, { "formSubmit": "formSubmit"; }, never, never, true, never>;
5
+ static ɵcmp: i0.ɵɵComponentDeclaration<DefaultFormsComponent, "default-forms", never, {}, {}, never, never, true, never>;
22
6
  }
@@ -1,19 +1,6 @@
1
- import { ChangeDetectorRef } from '@angular/core';
2
- import { FormGroup, FormBuilder } from '@angular/forms';
3
- import { FormControlConfig } from '../formControlConfig';
1
+ import { BaseFormsComponent } from '../base.component';
4
2
  import * as i0 from "@angular/core";
5
- export declare class MaterialFormsComponent {
6
- private fb;
7
- private cdr;
8
- formName: import("@angular/core").InputSignal<string>;
9
- controls: import("@angular/core").InputSignal<FormControlConfig[]>;
10
- formSubmit: import("@angular/core").OutputEmitterRef<Record<string, any>>;
11
- form: FormGroup;
12
- constructor(fb: FormBuilder, cdr: ChangeDetectorRef);
13
- ngOnInit(): void;
14
- private initializeForm;
15
- private getValidators;
16
- onSubmit(): void;
3
+ export declare class MaterialFormsComponent extends BaseFormsComponent {
17
4
  static ɵfac: i0.ɵɵFactoryDeclaration<MaterialFormsComponent, never>;
18
- static ɵcmp: i0.ɵɵComponentDeclaration<MaterialFormsComponent, "material-forms", never, { "formName": { "alias": "formName"; "required": true; "isSignal": true; }; "controls": { "alias": "controls"; "required": true; "isSignal": true; }; }, { "formSubmit": "formSubmit"; }, never, never, true, never>;
5
+ static ɵcmp: i0.ɵɵComponentDeclaration<MaterialFormsComponent, "material-forms", never, {}, {}, never, never, true, never>;
19
6
  }
@@ -1,23 +1,7 @@
1
- import { ChangeDetectorRef } from '@angular/core';
2
- import { FormGroup, FormBuilder } from '@angular/forms';
3
- import { FormControlConfig } from '../formControlConfig';
1
+ import { BaseFormsComponent } from '../base.component';
4
2
  import * as i0 from "@angular/core";
5
- export declare class PrimeNgFormsComponent {
6
- private fb;
7
- private cdr;
8
- formName: import("@angular/core").InputSignal<string>;
9
- controls: import("@angular/core").InputSignal<FormControlConfig[]>;
10
- formSubmit: import("@angular/core").OutputEmitterRef<Record<string, any>>;
11
- form: FormGroup;
12
- private formChanges$;
13
- constructor(fb: FormBuilder, cdr: ChangeDetectorRef);
14
- ngOnInit(): void;
15
- private initializeForm;
16
- private getValidators;
17
- private updateValidators;
18
- private shouldRequireValidation;
3
+ export declare class PrimeNgFormsComponent extends BaseFormsComponent {
19
4
  onFileSelect(event: any, controlName: string): void;
20
- onSubmit(): void;
21
5
  static ɵfac: i0.ɵɵFactoryDeclaration<PrimeNgFormsComponent, never>;
22
- static ɵcmp: i0.ɵɵComponentDeclaration<PrimeNgFormsComponent, "primeng-forms", never, { "formName": { "alias": "formName"; "required": true; "isSignal": true; }; "controls": { "alias": "controls"; "required": true; "isSignal": true; }; }, { "formSubmit": "formSubmit"; }, never, never, true, never>;
6
+ static ɵcmp: i0.ɵɵComponentDeclaration<PrimeNgFormsComponent, "primeng-forms", never, {}, {}, never, never, true, never>;
23
7
  }
@@ -0,0 +1,113 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { ChangeDetectionStrategy, Component, input, output, } from '@angular/core';
3
+ import { ReactiveFormsModule, FormsModule, Validators, } from '@angular/forms';
4
+ import { BehaviorSubject } from 'rxjs';
5
+ import { ValidationMessagesComponent } from './validation-messages/validation-messages.component';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@angular/forms";
8
+ export class BaseFormsComponent {
9
+ fb;
10
+ cdr;
11
+ formName = input.required();
12
+ controls = input.required();
13
+ formSubmit = output();
14
+ form;
15
+ formChanges$ = new BehaviorSubject(false);
16
+ constructor(fb, cdr) {
17
+ this.fb = fb;
18
+ this.cdr = cdr;
19
+ }
20
+ ngOnInit() {
21
+ this.initializeForm();
22
+ }
23
+ initializeForm() {
24
+ const formControls = {};
25
+ this.controls().forEach((control) => {
26
+ formControls[control.name] = [
27
+ control.value ?? '',
28
+ this.getValidators(control),
29
+ ];
30
+ });
31
+ this.form = this.fb.group(formControls);
32
+ this.controls().forEach((control) => {
33
+ const formControl = this.form.get(control.name);
34
+ if (formControl) {
35
+ formControl.valueChanges.subscribe((value) => {
36
+ // Only update validators if the value actually changes
37
+ if (formControl.value !== value) {
38
+ this.updateValidators(formControl, value);
39
+ }
40
+ });
41
+ }
42
+ });
43
+ this.formChanges$.subscribe(() => this.cdr.markForCheck());
44
+ }
45
+ getValidators(control) {
46
+ const validators = [];
47
+ if (control.validators) {
48
+ control.validators.forEach((validator) => {
49
+ if (validator.required)
50
+ validators.push(Validators.required);
51
+ if (validator.minlength)
52
+ validators.push(Validators.minLength(validator.minlength));
53
+ if (validator.maxlength)
54
+ validators.push(Validators.maxLength(validator.maxlength));
55
+ if (validator.pattern)
56
+ validators.push(Validators.pattern(validator.pattern));
57
+ if (validator.email)
58
+ validators.push(Validators.email);
59
+ if (validator.custom)
60
+ validators.push(validator.custom);
61
+ });
62
+ }
63
+ return validators;
64
+ }
65
+ updateValidators(control, value) {
66
+ const requiresValidation = this.shouldRequireValidation(value);
67
+ // Check if the validators need to be updated
68
+ const hasRequiredValidator = control.hasValidator(Validators.required);
69
+ if (requiresValidation && !hasRequiredValidator) {
70
+ control.addValidators(Validators.required);
71
+ control.updateValueAndValidity();
72
+ }
73
+ else if (!requiresValidation && hasRequiredValidator) {
74
+ control.removeValidators(Validators.required);
75
+ control.updateValueAndValidity();
76
+ }
77
+ this.formChanges$.next(true);
78
+ }
79
+ shouldRequireValidation(value) {
80
+ return value !== null && value !== '';
81
+ }
82
+ onSubmit() {
83
+ this.form.markAllAsTouched();
84
+ this.form.markAsDirty();
85
+ this.form.updateValueAndValidity();
86
+ if (this.form.valid) {
87
+ this.formSubmit.emit(this.form.value);
88
+ this.form.reset();
89
+ }
90
+ else {
91
+ console.error('Form Invalid');
92
+ }
93
+ this.formChanges$.next(true);
94
+ }
95
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BaseFormsComponent, deps: [{ token: i1.FormBuilder }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
96
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: BaseFormsComponent, isStandalone: true, selector: "base-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: '', isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "ngmodule", type: FormsModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
97
+ }
98
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BaseFormsComponent, decorators: [{
99
+ type: Component,
100
+ args: [{
101
+ selector: 'base-forms',
102
+ standalone: true,
103
+ imports: [
104
+ CommonModule,
105
+ ReactiveFormsModule,
106
+ FormsModule,
107
+ ValidationMessagesComponent,
108
+ ],
109
+ template: '',
110
+ changeDetection: ChangeDetectionStrategy.OnPush,
111
+ }]
112
+ }], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i0.ChangeDetectorRef }] });
113
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.component.js","sourceRoot":"","sources":["../../../../ngForm/src/app/base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { 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 { BehaviorSubject } from 'rxjs';\nimport { ValidationMessagesComponent } from './validation-messages/validation-messages.component';\nimport { FormControlConfig } from '../public-api';\n\n@Component({\n  selector: 'base-forms',\n  standalone: true,\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    FormsModule,\n    ValidationMessagesComponent,\n  ],\n  template: '',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class BaseFormsComponent {\n  formName = input.required<string>();\n  controls = input.required<FormControlConfig[]>();\n  formSubmit = output<Record<string, any>>();\n\n  form!: FormGroup;\n  protected formChanges$ = new BehaviorSubject<boolean>(false);\n\n  constructor(\n    protected fb: FormBuilder,\n    protected cdr: ChangeDetectorRef,\n  ) {}\n\n  ngOnInit(): void {\n    this.initializeForm();\n  }\n\n  protected initializeForm(): void {\n    const formControls: { [key: string]: any } = {};\n\n    this.controls().forEach((control) => {\n      formControls[control.name] = [\n        control.value ?? '',\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          // Only update validators if the value actually changes\n          if (formControl.value !== value) {\n            this.updateValidators(formControl, value);\n          }\n        });\n      }\n    });\n\n    this.formChanges$.subscribe(() => this.cdr.markForCheck());\n  }\n\n  protected 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  protected updateValidators(control: AbstractControl, value: any): void {\n    const requiresValidation = this.shouldRequireValidation(value);\n\n    // Check if the validators need to be updated\n    const hasRequiredValidator = control.hasValidator(Validators.required);\n\n    if (requiresValidation && !hasRequiredValidator) {\n      control.addValidators(Validators.required);\n      control.updateValueAndValidity();\n    } else if (!requiresValidation && hasRequiredValidator) {\n      control.removeValidators(Validators.required);\n      control.updateValueAndValidity();\n    }\n\n    this.formChanges$.next(true);\n  }\n\n  protected shouldRequireValidation(value: any): boolean {\n    return value !== null && value !== '';\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    } else {\n      console.error('Form Invalid');\n    }\n\n    this.formChanges$.next(true);\n  }\n}"]}
@@ -61,103 +61,25 @@
61
61
  * @description Handles the form submission. Marks the form as touched and dirty, validates the form, emits the form value if valid, and resets the form.
62
62
  */
63
63
  import { CommonModule } from '@angular/common';
64
- import { ChangeDetectionStrategy, Component, input, output, } from '@angular/core';
65
- import { ReactiveFormsModule, FormsModule, Validators, } from '@angular/forms';
64
+ import { ChangeDetectionStrategy, Component } from '@angular/core';
65
+ import { ReactiveFormsModule, FormsModule } from '@angular/forms';
66
66
  import { ValidationMessagesComponent } from '../validation-messages/validation-messages.component';
67
- import { BehaviorSubject } from 'rxjs';
67
+ import { BaseFormsComponent } from '../base.component';
68
68
  import * as i0 from "@angular/core";
69
69
  import * as i1 from "@angular/forms";
70
70
  import * as i2 from "@angular/common";
71
- export class DefaultFormsComponent {
72
- fb;
73
- cdr;
74
- formName = input.required();
75
- controls = input.required();
76
- formSubmit = output();
77
- form;
78
- formChanges$ = new BehaviorSubject(false);
79
- constructor(fb, cdr) {
80
- this.fb = fb;
81
- this.cdr = cdr;
82
- }
83
- ngOnInit() {
84
- this.initializeForm();
85
- }
86
- initializeForm() {
87
- const formControls = {};
88
- this.controls().forEach((control) => {
89
- formControls[control.name] = [
90
- control.value ?? '',
91
- this.getValidators(control),
92
- ];
93
- });
94
- this.form = this.fb.group(formControls);
95
- this.controls().forEach((control) => {
96
- const formControl = this.form.get(control.name);
97
- if (formControl) {
98
- formControl.valueChanges.subscribe((value) => {
99
- this.updateValidators(formControl, value);
100
- });
101
- }
102
- });
103
- this.formChanges$.subscribe(() => this.cdr.markForCheck());
104
- }
105
- getValidators(control) {
106
- const validators = [];
107
- if (control.validators) {
108
- control.validators.forEach((validator) => {
109
- if (validator.required)
110
- validators.push(Validators.required);
111
- if (validator.minlength)
112
- validators.push(Validators.minLength(validator.minlength));
113
- if (validator.maxlength)
114
- validators.push(Validators.maxLength(validator.maxlength));
115
- if (validator.pattern)
116
- validators.push(Validators.pattern(validator.pattern));
117
- if (validator.email)
118
- validators.push(Validators.email);
119
- if (validator.custom)
120
- validators.push(validator.custom);
121
- });
122
- }
123
- return validators;
124
- }
125
- updateValidators(control, value) {
126
- if (this.shouldRequireValidation(value)) {
127
- control.addValidators(Validators.required);
128
- }
129
- else {
130
- control.removeValidators(Validators.required);
131
- }
132
- control.updateValueAndValidity();
133
- this.formChanges$.next(true);
134
- }
135
- shouldRequireValidation(value) {
136
- return value !== null && value !== '';
137
- }
138
- onSubmit() {
139
- this.form.markAllAsTouched();
140
- this.form.markAsDirty();
141
- this.form.updateValueAndValidity();
142
- if (this.form.valid) {
143
- this.formSubmit.emit(this.form.value);
144
- this.form.reset();
145
- }
146
- else {
147
- console.error('Form Invalid');
148
- }
149
- this.formChanges$.next(true);
150
- }
151
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DefaultFormsComponent, deps: [{ token: i1.FormBuilder }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
152
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DefaultFormsComponent, isStandalone: true, selector: "default-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 === \"default\" || !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 @if (control.type === \"input\") {\n <input\n [formControlName]=\"control.name\"\n [id]=\"control.name\"\n type=\"text\"\n />\n }\n @if (control.type === \"select\") {\n <select [formControlName]=\"control.name\" [id]=\"control.name\">\n @for (option of control.options; track $index) {\n <option [value]=\"option\">{{ option }}</option>\n }\n </select>\n }\n @if (control.type === \"textarea\") {\n <textarea\n [formControlName]=\"control.name\"\n [id]=\"control.name\"\n ></textarea>\n }\n @if (control.type === \"checkbox\") {\n <input\n type=\"checkbox\"\n [formControlName]=\"control.name\"\n [id]=\"control.name\"\n />\n }\n @if (control.type === \"radio\") {\n @for (option of control.options ?? []; track $index) {\n <div>\n <input\n type=\"radio\"\n [formControlName]=\"control.name\"\n [id]=\"control.name + '-' + option\"\n [value]=\"option\"\n />\n <label [for]=\"control.name + '-' + option\">{{ option }}</label>\n </div>\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 type=\"submit\" [disabled]=\"form.invalid\">Submit</button>\n</form>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { 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.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i1.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i1.RadioControlValueAccessor, selector: "input[type=radio][formControlName],input[type=radio][formControl],input[type=radio][ngModel]", inputs: ["name", "formControlName", "value"] }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { 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: "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: "component", type: ValidationMessagesComponent, selector: "validation-messages", inputs: ["control", "controlName", "config"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
71
+ export class DefaultFormsComponent extends BaseFormsComponent {
72
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DefaultFormsComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
73
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DefaultFormsComponent, isStandalone: true, selector: "default-forms", usesInheritance: true, ngImport: i0, template: "<form [formGroup]=\"form\" [attr.name]=\"formName()\" (ngSubmit)=\"onSubmit()\">\n @for (control of controls(); track $index) {\n @if (control.uiFramework === \"default\" || !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 @if (control.type === \"input\") {\n <input\n [formControlName]=\"control.name\"\n [id]=\"control.name\"\n type=\"text\"\n />\n }\n @if (control.type === \"select\") {\n <select [formControlName]=\"control.name\" [id]=\"control.name\">\n @for (option of control.options; track $index) {\n <option [value]=\"option\">{{ option }}</option>\n }\n </select>\n }\n @if (control.type === \"textarea\") {\n <textarea\n [formControlName]=\"control.name\"\n [id]=\"control.name\"\n ></textarea>\n }\n @if (control.type === \"checkbox\") {\n <input\n type=\"checkbox\"\n [formControlName]=\"control.name\"\n [id]=\"control.name\"\n />\n }\n @if (control.type === \"radio\") {\n @for (option of control.options ?? []; track $index) {\n <div>\n <input\n type=\"radio\"\n [formControlName]=\"control.name\"\n [id]=\"control.name + '-' + option\"\n [value]=\"option\"\n />\n <label [for]=\"control.name + '-' + option\">{{ option }}</label>\n </div>\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 type=\"submit\" [disabled]=\"form.invalid\">Submit</button>\n</form>\n", dependencies: [{ kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { 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.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i1.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i1.RadioControlValueAccessor, selector: "input[type=radio][formControlName],input[type=radio][formControl],input[type=radio][ngModel]", inputs: ["name", "formControlName", "value"] }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { 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: "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: "component", type: ValidationMessagesComponent, selector: "validation-messages", inputs: ["control", "controlName", "config"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
153
74
  }
154
75
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DefaultFormsComponent, decorators: [{
155
76
  type: Component,
156
77
  args: [{ selector: 'default-forms', standalone: true, imports: [
78
+ BaseFormsComponent,
157
79
  ReactiveFormsModule,
158
80
  CommonModule,
159
81
  FormsModule,
160
82
  ValidationMessagesComponent,
161
83
  ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<form [formGroup]=\"form\" [attr.name]=\"formName()\" (ngSubmit)=\"onSubmit()\">\n @for (control of controls(); track $index) {\n @if (control.uiFramework === \"default\" || !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 @if (control.type === \"input\") {\n <input\n [formControlName]=\"control.name\"\n [id]=\"control.name\"\n type=\"text\"\n />\n }\n @if (control.type === \"select\") {\n <select [formControlName]=\"control.name\" [id]=\"control.name\">\n @for (option of control.options; track $index) {\n <option [value]=\"option\">{{ option }}</option>\n }\n </select>\n }\n @if (control.type === \"textarea\") {\n <textarea\n [formControlName]=\"control.name\"\n [id]=\"control.name\"\n ></textarea>\n }\n @if (control.type === \"checkbox\") {\n <input\n type=\"checkbox\"\n [formControlName]=\"control.name\"\n [id]=\"control.name\"\n />\n }\n @if (control.type === \"radio\") {\n @for (option of control.options ?? []; track $index) {\n <div>\n <input\n type=\"radio\"\n [formControlName]=\"control.name\"\n [id]=\"control.name + '-' + option\"\n [value]=\"option\"\n />\n <label [for]=\"control.name + '-' + option\">{{ option }}</label>\n </div>\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 type=\"submit\" [disabled]=\"form.invalid\">Submit</button>\n</form>\n" }]
162
- }], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i0.ChangeDetectorRef }] });
163
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"default-forms.component.js","sourceRoot":"","sources":["../../../../../ngForm/src/app/default-forms/default-forms.component.ts","../../../../../ngForm/src/app/default-forms/default-forms.component.html"],"names":[],"mappings":"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","sourcesContent":["/**\n * @component DefaultFormsComponent\n * @description\n * The `DefaultFormsComponent` is an Angular standalone component that provides a dynamic form generation\n * based on the provided configuration. It uses reactive forms to handle form controls and their validations.\n * The component is designed to be highly configurable and supports various types of form validators.\n *\n * @selector default-forms\n * @standalone true\n * @imports\n * - ReactiveFormsModule\n * - CommonModule\n * - FormsModule\n * - ValidationMessagesComponent\n * @templateUrl ./default-forms.component.html\n * @styleUrl ./default-forms.component.css\n * @changeDetection ChangeDetectionStrategy.OnPush\n *\n * @input\n * - `formName: string` - The name of the form.\n * - `controls: FormControlConfig[]` - An array of form control configurations.\n *\n * @output\n * - `formSubmit: EventEmitter<Record<string, any>>` - Emits the form value when the form is submitted.\n *\n * @class DefaultFormsComponent\n * @implements OnInit\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 instance.\n * @property {BehaviorSubject<boolean>} formChanges$ - A subject to track form changes.\n *\n * @constructor\n * @param {FormBuilder} fb - Angular's FormBuilder service to create form controls.\n * @param {ChangeDetectorRef} cdr - Angular's ChangeDetectorRef service to manually trigger change detection.\n *\n * @method ngOnInit\n * @description Lifecycle hook that is called after the component's view has been initialized. It initializes the form.\n *\n * @method initializeForm\n * @description Initializes the form by creating form controls based on the provided configuration and sets up value change subscriptions.\n *\n * @method getValidators\n * @param {FormControlConfig} control - The configuration for a form control.\n * @returns {ValidatorFn[]} An array of validators for the form control.\n * @description Generates an array of validators based on the provided control configuration.\n *\n * @method updateValidators\n * @param {AbstractControl} control - The form control to update validators for.\n * @param {any} value - The current value of the form control.\n * @description Updates the validators for a form control based on its current value.\n *\n * @method shouldRequireValidation\n * @param {any} value - The value to check for validation requirement.\n * @returns {boolean} Whether the value requires validation.\n * @description Determines if a value should require validation.\n *\n * @method onSubmit\n * @description Handles the form submission. Marks the form as touched and dirty, validates the form, emits the form value if valid, and resets the form.\n */\nimport { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  input,\n  output,\n  signal,\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';\n\n@Component({\n  selector: 'default-forms',\n  standalone: true,\n  imports: [\n    ReactiveFormsModule,\n    CommonModule,\n    FormsModule,\n    ValidationMessagesComponent,\n  ],\n  templateUrl: './default-forms.component.html',\n  styleUrl: './default-forms.component.css',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DefaultFormsComponent {\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 ?? '',\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  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    } 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 === \"default\" || !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          @if (control.type === \"input\") {\n            <input\n              [formControlName]=\"control.name\"\n              [id]=\"control.name\"\n              type=\"text\"\n            />\n          }\n          @if (control.type === \"select\") {\n            <select [formControlName]=\"control.name\" [id]=\"control.name\">\n              @for (option of control.options; track $index) {\n                <option [value]=\"option\">{{ option }}</option>\n              }\n            </select>\n          }\n          @if (control.type === \"textarea\") {\n            <textarea\n              [formControlName]=\"control.name\"\n              [id]=\"control.name\"\n            ></textarea>\n          }\n          @if (control.type === \"checkbox\") {\n            <input\n              type=\"checkbox\"\n              [formControlName]=\"control.name\"\n              [id]=\"control.name\"\n            />\n          }\n          @if (control.type === \"radio\") {\n            @for (option of control.options ?? []; track $index) {\n              <div>\n                <input\n                  type=\"radio\"\n                  [formControlName]=\"control.name\"\n                  [id]=\"control.name + '-' + option\"\n                  [value]=\"option\"\n                />\n                <label [for]=\"control.name + '-' + option\">{{ option }}</label>\n              </div>\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 type=\"submit\" [disabled]=\"form.invalid\">Submit</button>\n</form>\n"]}
84
+ }] });
85
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"default-forms.component.js","sourceRoot":"","sources":["../../../../../ngForm/src/app/default-forms/default-forms.component.ts","../../../../../ngForm/src/app/default-forms/default-forms.component.html"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6DG;AACH,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AACnE,OAAO,EAAE,mBAAmB,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAClE,OAAO,EAAE,2BAA2B,EAAE,MAAM,sDAAsD,CAAC;AACnG,OAAO,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;;;;AAevD,MAAM,OAAO,qBAAsB,SAAQ,kBAAkB;wGAAhD,qBAAqB;4FAArB,qBAAqB,gGCjFlC,yyEAmEA,2CDMI,mBAAmB,2uDACnB,YAAY,iNACZ,WAAW,+BACX,2BAA2B;;4FAKlB,qBAAqB;kBAbjC,SAAS;+BACE,eAAe,cACb,IAAI,WACP;wBACP,kBAAkB;wBAClB,mBAAmB;wBACnB,YAAY;wBACZ,WAAW;wBACX,2BAA2B;qBAC5B,mBAEgB,uBAAuB,CAAC,MAAM","sourcesContent":["/**\n * @component DefaultFormsComponent\n * @description\n * The `DefaultFormsComponent` is an Angular standalone component that provides a dynamic form generation\n * based on the provided configuration. It uses reactive forms to handle form controls and their validations.\n * The component is designed to be highly configurable and supports various types of form validators.\n *\n * @selector default-forms\n * @standalone true\n * @imports\n * - ReactiveFormsModule\n * - CommonModule\n * - FormsModule\n * - ValidationMessagesComponent\n * @templateUrl ./default-forms.component.html\n * @styleUrl ./default-forms.component.css\n * @changeDetection ChangeDetectionStrategy.OnPush\n *\n * @input\n * - `formName: string` - The name of the form.\n * - `controls: FormControlConfig[]` - An array of form control configurations.\n *\n * @output\n * - `formSubmit: EventEmitter<Record<string, any>>` - Emits the form value when the form is submitted.\n *\n * @class DefaultFormsComponent\n * @implements OnInit\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 instance.\n * @property {BehaviorSubject<boolean>} formChanges$ - A subject to track form changes.\n *\n * @constructor\n * @param {FormBuilder} fb - Angular's FormBuilder service to create form controls.\n * @param {ChangeDetectorRef} cdr - Angular's ChangeDetectorRef service to manually trigger change detection.\n *\n * @method ngOnInit\n * @description Lifecycle hook that is called after the component's view has been initialized. It initializes the form.\n *\n * @method initializeForm\n * @description Initializes the form by creating form controls based on the provided configuration and sets up value change subscriptions.\n *\n * @method getValidators\n * @param {FormControlConfig} control - The configuration for a form control.\n * @returns {ValidatorFn[]} An array of validators for the form control.\n * @description Generates an array of validators based on the provided control configuration.\n *\n * @method updateValidators\n * @param {AbstractControl} control - The form control to update validators for.\n * @param {any} value - The current value of the form control.\n * @description Updates the validators for a form control based on its current value.\n *\n * @method shouldRequireValidation\n * @param {any} value - The value to check for validation requirement.\n * @returns {boolean} Whether the value requires validation.\n * @description Determines if a value should require validation.\n *\n * @method onSubmit\n * @description Handles the form submission. Marks the form as touched and dirty, validates the form, emits the form value if valid, and resets the form.\n */\nimport { CommonModule } from '@angular/common';\nimport { ChangeDetectionStrategy, Component } from '@angular/core';\nimport { ReactiveFormsModule, FormsModule } from '@angular/forms';\nimport { ValidationMessagesComponent } from '../validation-messages/validation-messages.component';\nimport { BaseFormsComponent } from '../base.component';\n\n@Component({\n  selector: 'default-forms',\n  standalone: true,\n  imports: [\n    BaseFormsComponent,\n    ReactiveFormsModule,\n    CommonModule,\n    FormsModule,\n    ValidationMessagesComponent,\n  ],\n  templateUrl: './default-forms.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DefaultFormsComponent extends BaseFormsComponent {}\n","<form [formGroup]=\"form\" [attr.name]=\"formName()\" (ngSubmit)=\"onSubmit()\">\n  @for (control of controls(); track $index) {\n    @if (control.uiFramework === \"default\" || !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          @if (control.type === \"input\") {\n            <input\n              [formControlName]=\"control.name\"\n              [id]=\"control.name\"\n              type=\"text\"\n            />\n          }\n          @if (control.type === \"select\") {\n            <select [formControlName]=\"control.name\" [id]=\"control.name\">\n              @for (option of control.options; track $index) {\n                <option [value]=\"option\">{{ option }}</option>\n              }\n            </select>\n          }\n          @if (control.type === \"textarea\") {\n            <textarea\n              [formControlName]=\"control.name\"\n              [id]=\"control.name\"\n            ></textarea>\n          }\n          @if (control.type === \"checkbox\") {\n            <input\n              type=\"checkbox\"\n              [formControlName]=\"control.name\"\n              [id]=\"control.name\"\n            />\n          }\n          @if (control.type === \"radio\") {\n            @for (option of control.options ?? []; track $index) {\n              <div>\n                <input\n                  type=\"radio\"\n                  [formControlName]=\"control.name\"\n                  [id]=\"control.name + '-' + option\"\n                  [value]=\"option\"\n                />\n                <label [for]=\"control.name + '-' + option\">{{ option }}</label>\n              </div>\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 type=\"submit\" [disabled]=\"form.invalid\">Submit</button>\n</form>\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formControlConfig.js","sourceRoot":"","sources":["../../../../ngForm/src/app/formControlConfig.ts"],"names":[],"mappings":"","sourcesContent":["import { ValidatorFn } from \"@angular/forms\";\n\n\n/**\n * Interface representing the configuration for a form control.\n */\nexport interface FormControlConfig {\n  /**\n   * The name of the form control.\n   */\n  name: string;\n\n  /**\n   * The type of the form control. Possible values include 'input', 'select', 'textarea', 'checkbox', 'radio', 'file', 'calendar', etc.\n   */\n  type: string;\n\n  /**\n   * Options for 'select', 'radio', 'dropdown' controls. Each option can be an object with a label and value or a string.\n   */\n  options?: Array<{ label: string; value: any } | string>;\n\n  /**\n   * Validators for the form control. Includes standard validators like required, minlength, maxlength, pattern, email, and custom validators.\n   */\n  validators?: {\n    required?: boolean;\n    minlength?: number;\n    maxlength?: number;\n    pattern?: string;\n    email?: boolean;\n    custom?: ValidatorFn;\n  }[];\n\n  /**\n   * CSS classes to be applied to the form control.\n   */\n  class?: string;\n\n  /**\n   * Inline styles to be applied to the form control.\n   */\n  style?: any;\n\n  /**\n   * Default value for the form control.\n   */\n  value?: any;\n\n  /**\n   * UI framework to be used for the form control. Possible values are 'material', 'primeng', 'default'.\n   */\n  uiFramework?: 'material' | 'primeng' | 'default';\n\n  /**\n   * Label for the form control.\n   */\n  label?: string;\n\n  /**\n   * CSS classes to be applied to the label of the form control.\n   */\n  labelClass?: string;\n\n  /**\n   * Inline styles to be applied to the label of the form control.\n   */\n  labelStyle?: any;\n\n  /**\n   * Mode for date picker controls. Possible values are 'single' and 'range'.\n   */\n  datePickerMode?: 'single' | 'range';\n\n  /**\n   * PrimeNG-specific properties for the form control.\n   */\n  primeng?: {\n    icon?: string;\n    showClear?: boolean;\n    multiple?: boolean;\n    maxFileSize?: number;\n    accept?: string;\n    showWeek?: boolean;\n    minDate?: Date;\n    maxDate?: Date;\n    mode?: 'basic' | 'advanced';\n    currency?: string;\n    decimalSeparator?: string;\n    step?: number;\n    range?: boolean;\n    scrollHeight?: string;\n    showToggleAll?: boolean;\n    showButtons?: boolean;\n    panelClass?: string;\n    chooseLabel?: string;\n    clearLabel?: string;\n    todayLabel?: string;\n    timeOnly?: boolean;\n    hourFormat?: string;\n    minuteFormat?: string;\n    secondsFormat?: string;\n    showSeconds?: boolean;\n    showMillisec?: boolean;\n    timeSeparator?: string;\n    showOnFocus?: boolean;\n    appendTo?: string;\n    inputStyle?: any;\n    inputStyleClass?: string;\n    uploadLabel?: string;\n    cancelLabel?: string;\n    auto?: boolean;\n    url?: string;\n    withCredentials?: boolean;\n    customUpload?: string;\n    showUploadButton?: boolean;\n    showCancelButton?: boolean;\n    showUploadIcon?: boolean;\n    showRemoveIcon?: boolean;\n    showPreview?: boolean;\n    previewWidth?: number;\n    chooseOptions?: any;\n    showTime?: boolean;\n    showDate?: boolean;\n    showIcon?: boolean;\n    iconPos?: 'left' | 'right';\n  };\n\n  /**\n   * Angular-specific properties for the form control.\n   */\n  angular?: {\n    readonly?: boolean;\n    autocomplete?: 'on' | 'off';\n    autofocus?: boolean;\n    placeholder?: string;\n    mask?: string;\n    tooltip?: string;\n    icon?: string;\n    prefix?: string;\n    suffix?: string;\n    hint?: string;\n    tabIndex?: number;\n    color?: string;\n    theme?: 'dark' | 'light' | string;\n  };\n\n  /**\n   * Configuration for dependent fields. Specifies fields that depend on the value of this field and the condition for their dependency.\n   */\n  dependentFields?: {\n    dependsOn: string;\n    condition: (value: any) => boolean;\n  }[];\n\n  /**\n   * Indicates if the form control is repeatable.\n   */\n  repeatable?: boolean;\n\n  /**\n   * Function to conditionally render the form control based on the values of other controls.\n   */\n  conditionalRender?: (values: any) => boolean;\n\n  /**\n   * Group to which the form control belongs.\n   */\n  group?: string;\n\n  /**\n   * Event handlers for various events related to the form control.\n   */\n  events?: {\n    onChange?: (event: any) => void;\n    onFocus?: (event: any) => void;\n    onBlur?: (event: any) => void;\n    onSelect?: (event: any) => void;\n    onUpload?: (event: any) => void;\n    onKeyUp?: (event: any) => void;\n    onKeyDown?: (event: any) => void;\n    onPaste?: (event: any) => void;\n    onDownload?: (event: any) => void;\n    onClear?: (event: any) => void;\n    onReset?: (event: any) => void;\n    onToggle?: (event: any) => void;\n    onShow?: (event: any) => void;\n    onHide?: (event: any) => void;\n    onOpen?: (event: any) => void;\n    onClose?: (event: any) => void;\n    onPanelClick?: (event: any) => void;\n    onPanelShow?: (event: any) => void;\n    onPanelHide?: (event: any) => void;\n    onPanelOpen?: (event: any) => void;\n    onPanelClose?: (event: any) => void;\n    onPanelToggle?: (event: any) => void;\n    onPanelSelect?: (event: any) => void;\n    onPanelUnselect?: (event: any) => void;\n    onPanelUnselectAll?: (event: any) => void;\n    onPanelReorder?: (event: any) => void;\n    onPanelResize?: (event: any) => void;\n    onPanelDragStart?: (event: any) => void;\n    onPanelDragEnd?: (event: any) => void;\n    onPanelDragOver?: (event: any) => void;\n    onPanelDragLeave?: (event: any) => void;\n    onPanelDrop?: (event: any) => void;\n    onPanelScroll?: (event: any) => void;\n    onPanelFilter?: (event: any) => void;\n    onPanelToggleAll?: (event: any) => void;\n    onPanelShowAll?: (event: any) => void;\n    onPanelHideAll?: (event: any) => void;\n    onPanelOpenAll?: (event: any) => void;\n    onPanelCloseAll?: (event: any) => void;\n    onRemove?: (event: any) => void;\n    onError?: (event: any) => void;\n    onBeforeUpload?: (event: any) => void;\n    onProgress?: (event: any) => void;\n    onSlideEnd?: (event: any) => void;\n  };\n}\n"]}
2
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formControlConfig.js","sourceRoot":"","sources":["../../../../ngForm/src/app/formControlConfig.ts"],"names":[],"mappings":"","sourcesContent":["import { ValidatorFn } from \"@angular/forms\";\n\n\n/**\n * Interface representing the configuration for a form control.\n */\nexport interface FormControlConfig {\n  /**\n   * The name of the form control.\n   */\n  name: string;\n\n  /**\n   * The type of the form control. Possible values include 'input', 'select', 'textarea', 'checkbox', 'radio', 'file', 'calendar', etc.\n   */\n  type: string;\n \n  /**\n   * Options for 'select', 'radio', 'dropdown' controls. Each option can be an object with a label and value or a string.\n   */\n  options?: Array<{ label: string; value: any } | string>;\n\n  /**\n   * Validators for the form control. Includes standard validators like required, minlength, maxlength, pattern, email, and custom validators.\n   */\n  validators?: {\n    required?: boolean;\n    minlength?: number;\n    maxlength?: number;\n    pattern?: string;\n    email?: boolean;\n    custom?: ValidatorFn;\n  }[];\n\n  /**\n   * CSS classes to be applied to the form control.\n   */\n  class?: string;\n\n  /**\n   * Inline styles to be applied to the form control.\n   */\n  style?: any;\n\n  /**\n   * Default value for the form control.\n   */\n  value?: any;\n\n  /**\n   * UI framework to be used for the form control. Possible values are 'material', 'primeng', 'default'.\n   */\n  uiFramework?: 'material' | 'primeng' | 'default';\n\n  /**\n   * Label for the form control.\n   */\n  label?: string;\n\n  /**\n   * CSS classes to be applied to the label of the form control.\n   */\n  labelClass?: string;\n\n  /**\n   * Inline styles to be applied to the label of the form control.\n   */\n  labelStyle?: any;\n\n  /**\n   * Mode for date picker controls. Possible values are 'single' and 'range'.\n   */\n  datePickerMode?: 'single' | 'range';\n\n  /**\n   * PrimeNG-specific properties for the form control.\n   */\n  primeng?: {\n    icon?: string;\n    showClear?: boolean;\n    multiple?: boolean;\n    maxFileSize?: number;\n    accept?: string;\n    showWeek?: boolean;\n    minDate?: Date;\n    maxDate?: Date;\n    mode?: 'basic' | 'advanced';\n    currency?: string;\n    decimalSeparator?: string;\n    step?: number;\n    range?: boolean;\n    scrollHeight?: string;\n    showToggleAll?: boolean;\n    showButtons?: boolean;\n    panelClass?: string;\n    chooseLabel?: string;\n    clearLabel?: string;\n    todayLabel?: string;\n    timeOnly?: boolean;\n    hourFormat?: string;\n    minuteFormat?: string;\n    secondsFormat?: string;\n    showSeconds?: boolean;\n    showMillisec?: boolean;\n    timeSeparator?: string;\n    showOnFocus?: boolean;\n    appendTo?: string;\n    inputStyle?: any;\n    inputStyleClass?: string;\n    uploadLabel?: string;\n    cancelLabel?: string;\n    auto?: boolean;\n    url?: string;\n    withCredentials?: boolean;\n    customUpload?: string;\n    showUploadButton?: boolean;\n    showCancelButton?: boolean;\n    showUploadIcon?: boolean;\n    showRemoveIcon?: boolean;\n    showPreview?: boolean;\n    previewWidth?: number;\n    chooseOptions?: any;\n    showTime?: boolean;\n    showDate?: boolean;\n    showIcon?: boolean;\n    iconPos?: 'left' | 'right';\n  };\n\n  /**\n   * Angular-specific properties for the form control.\n   */\n  angular?: {\n    readonly?: boolean;\n    autocomplete?: 'on' | 'off';\n    autofocus?: boolean;\n    placeholder?: string;\n    mask?: string;\n    tooltip?: string;\n    icon?: string;\n    prefix?: string;\n    suffix?: string;\n    hint?: string;\n    tabIndex?: number;\n    color?: string;\n    theme?: 'dark' | 'light' | string;\n  };\n\n  /**\n   * Configuration for dependent fields. Specifies fields that depend on the value of this field and the condition for their dependency.\n   */\n  dependentFields?: {\n    dependsOn: string;\n    condition: (value: any) => boolean;\n  }[];\n\n  /**\n   * Indicates if the form control is repeatable.\n   */\n  repeatable?: boolean;\n\n  /**\n   * Function to conditionally render the form control based on the values of other controls.\n   */\n  conditionalRender?: (values: any) => boolean;\n\n  /**\n   * Group to which the form control belongs.\n   */\n  group?: string;\n\n  /**\n   * Event handlers for various events related to the form control.\n   */\n  events?: {\n    onChange?: (event: any) => void;\n    onFocus?: (event: any) => void;\n    onBlur?: (event: any) => void;\n    onSelect?: (event: any) => void;\n    onUpload?: (event: any) => void;\n    onKeyUp?: (event: any) => void;\n    onKeyDown?: (event: any) => void;\n    onPaste?: (event: any) => void;\n    onDownload?: (event: any) => void;\n    onClear?: (event: any) => void;\n    onReset?: (event: any) => void;\n    onToggle?: (event: any) => void;\n    onShow?: (event: any) => void;\n    onHide?: (event: any) => void;\n    onOpen?: (event: any) => void;\n    onClose?: (event: any) => void;\n    onPanelClick?: (event: any) => void;\n    onPanelShow?: (event: any) => void;\n    onPanelHide?: (event: any) => void;\n    onPanelOpen?: (event: any) => void;\n    onPanelClose?: (event: any) => void;\n    onPanelToggle?: (event: any) => void;\n    onPanelSelect?: (event: any) => void;\n    onPanelUnselect?: (event: any) => void;\n    onPanelUnselectAll?: (event: any) => void;\n    onPanelReorder?: (event: any) => void;\n    onPanelResize?: (event: any) => void;\n    onPanelDragStart?: (event: any) => void;\n    onPanelDragEnd?: (event: any) => void;\n    onPanelDragOver?: (event: any) => void;\n    onPanelDragLeave?: (event: any) => void;\n    onPanelDrop?: (event: any) => void;\n    onPanelScroll?: (event: any) => void;\n    onPanelFilter?: (event: any) => void;\n    onPanelToggleAll?: (event: any) => void;\n    onPanelShowAll?: (event: any) => void;\n    onPanelHideAll?: (event: any) => void;\n    onPanelOpenAll?: (event: any) => void;\n    onPanelCloseAll?: (event: any) => void;\n    onRemove?: (event: any) => void;\n    onError?: (event: any) => void;\n    onBeforeUpload?: (event: any) => void;\n    onProgress?: (event: any) => void;\n    onSlideEnd?: (event: any) => void;\n  };\n}\n"]}