UNPKG

@ng-dynamic-forms/ui-bootstrap

Version:

Bootstrap UI package for NG Dynamic Forms

180 lines 47.5 kB
import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, HostBinding, Input, Output, ViewChild, ViewChildren, ViewContainerRef } from "@angular/core"; import { ReactiveFormsModule } from "@angular/forms"; import { DYNAMIC_FORM_CONTROL_TYPE_ARRAY, DYNAMIC_FORM_CONTROL_TYPE_CHECKBOX, DYNAMIC_FORM_CONTROL_TYPE_CHECKBOX_GROUP, DYNAMIC_FORM_CONTROL_TYPE_DATEPICKER, DYNAMIC_FORM_CONTROL_TYPE_GROUP, DYNAMIC_FORM_CONTROL_TYPE_INPUT, DYNAMIC_FORM_CONTROL_TYPE_RADIO_GROUP, DYNAMIC_FORM_CONTROL_TYPE_RATING, DYNAMIC_FORM_CONTROL_TYPE_SELECT, DYNAMIC_FORM_CONTROL_TYPE_TEXTAREA, DYNAMIC_FORM_CONTROL_TYPE_TIMEPICKER, DynamicFormControlContainerComponent, DynamicTemplateDirective, DynamicFormArrayComponent, DynamicFormGroupComponent } from "@ng-dynamic-forms/core"; import { DynamicBootstrapCheckboxComponent } from "./checkbox/dynamic-bootstrap-checkbox.component"; import { DynamicBootstrapDatePickerComponent } from "./datepicker/dynamic-bootstrap-datepicker.component"; import { DynamicBootstrapInputComponent } from "./input/dynamic-bootstrap-input.component"; import { DynamicBootstrapRadioGroupComponent } from "./radio-group/dynamic-bootstrap-radio-group.component"; import { DynamicBootstrapRatingComponent } from "./rating/dynamic-bootstrap-rating.component"; import { DynamicBootstrapSelectComponent } from "./select/dynamic-bootstrap-select.component"; import { DynamicBootstrapTextAreaComponent } from "./textarea/dynamic-bootstrap-textarea.component"; import { DynamicBootstrapTimePickerComponent } from "./timepicker/dynamic-bootstrap-timepicker.component"; import { NgClass, NgFor, NgTemplateOutlet, NgIf } from "@angular/common"; import * as i0 from "@angular/core"; import * as i1 from "@ng-dynamic-forms/core"; import * as i2 from "@angular/forms"; export class DynamicBootstrapFormControlContainerComponent extends DynamicFormControlContainerComponent { get componentType() { return this.componentService.getCustomComponentType(this.model) || bootstrapUIFormControlMapFn(this.model); } constructor(changeDetectorRef, componentFactoryResolver, layoutService, validationService, componentService, relationService) { super(changeDetectorRef, componentFactoryResolver, layoutService, validationService, componentService, relationService); this.changeDetectorRef = changeDetectorRef; this.componentFactoryResolver = componentFactoryResolver; this.layoutService = layoutService; this.validationService = validationService; this.componentService = componentService; this.relationService = relationService; this.asBootstrapFormGroup = true; this.context = null; this.blur = new EventEmitter(); this.change = new EventEmitter(); this.focus = new EventEmitter(); // tslint:disable-next-line:no-output-rename this.customEvent = new EventEmitter(); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: DynamicBootstrapFormControlContainerComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ComponentFactoryResolver }, { token: i1.DynamicFormLayoutService }, { token: i1.DynamicFormValidationService }, { token: i1.DynamicFormComponentService }, { token: i1.DynamicFormRelationService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.3", type: DynamicBootstrapFormControlContainerComponent, isStandalone: true, selector: "dynamic-bootstrap-form-control", inputs: { asBootstrapFormGroup: "asBootstrapFormGroup", context: "context", group: "group", hostClass: "hostClass", inputTemplateList: ["templates", "inputTemplateList"], layout: "layout", model: "model" }, outputs: { blur: "blur", change: "change", focus: "focus", customEvent: "bsEvent" }, host: { properties: { "class": "this.klass" } }, queries: [{ propertyName: "contentTemplateList", predicate: DynamicTemplateDirective }], viewQueries: [{ propertyName: "componentViewContainerRef", first: true, predicate: ["componentViewContainer"], descendants: true, read: ViewContainerRef, static: true }], usesInheritance: true, ngImport: i0, template: "<div [class.form-group]=\"asBootstrapFormGroup || getClass('element', 'container').includes('form-group')\"\n [class.has-error]=\"showErrorMessages\"\n [formGroup]=\"group\"\n [ngClass]=\"['ng-dynamic-forms-'+model.type.toLowerCase(), getClass('element', 'container'), getClass('grid', 'container')]\">\n\n <label *ngIf=\"!isCheckbox && hasLabel\"\n [for]=\"id\"\n [innerHTML]=\"model.label\"\n [ngClass]=\"[getClass('element', 'label'), getClass('grid', 'label')]\"></label>\n\n <ng-container *ngTemplateOutlet=\"startTemplate?.templateRef; context: model\"></ng-container>\n\n <div [ngClass]=\"getClass('grid', 'control')\">\n\n <ng-container #componentViewContainer></ng-container>\n\n <span *ngIf=\"hasHint\" class=\"help-block\" [innerHTML]=\"hint\"\n [ngClass]=\"getClass('element', 'hint')\"></span>\n\n </div>\n\n <ul *ngIf=\"showErrorMessages\" class=\"has-error\"\n [ngClass]=\"[getClass('element', 'errors'), getClass('grid', 'errors')]\">\n\n <li *ngFor=\"let message of errorMessages\" class=\"help-block\">{{ message }}</li>\n\n </ul>\n\n <ng-container *ngTemplateOutlet=\"endTemplate?.templateRef; context: model\"></ng-container>\n\n <ng-content></ng-content>\n\n</div>\n", dependencies: [{ kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: DynamicBootstrapFormControlContainerComponent, decorators: [{ type: Component, args: [{ selector: "dynamic-bootstrap-form-control", changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [ReactiveFormsModule, NgClass, NgIf, NgTemplateOutlet, NgFor], template: "<div [class.form-group]=\"asBootstrapFormGroup || getClass('element', 'container').includes('form-group')\"\n [class.has-error]=\"showErrorMessages\"\n [formGroup]=\"group\"\n [ngClass]=\"['ng-dynamic-forms-'+model.type.toLowerCase(), getClass('element', 'container'), getClass('grid', 'container')]\">\n\n <label *ngIf=\"!isCheckbox && hasLabel\"\n [for]=\"id\"\n [innerHTML]=\"model.label\"\n [ngClass]=\"[getClass('element', 'label'), getClass('grid', 'label')]\"></label>\n\n <ng-container *ngTemplateOutlet=\"startTemplate?.templateRef; context: model\"></ng-container>\n\n <div [ngClass]=\"getClass('grid', 'control')\">\n\n <ng-container #componentViewContainer></ng-container>\n\n <span *ngIf=\"hasHint\" class=\"help-block\" [innerHTML]=\"hint\"\n [ngClass]=\"getClass('element', 'hint')\"></span>\n\n </div>\n\n <ul *ngIf=\"showErrorMessages\" class=\"has-error\"\n [ngClass]=\"[getClass('element', 'errors'), getClass('grid', 'errors')]\">\n\n <li *ngFor=\"let message of errorMessages\" class=\"help-block\">{{ message }}</li>\n\n </ul>\n\n <ng-container *ngTemplateOutlet=\"endTemplate?.templateRef; context: model\"></ng-container>\n\n <ng-content></ng-content>\n\n</div>\n" }] }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ComponentFactoryResolver }, { type: i1.DynamicFormLayoutService }, { type: i1.DynamicFormValidationService }, { type: i1.DynamicFormComponentService }, { type: i1.DynamicFormRelationService }]; }, propDecorators: { contentTemplateList: [{ type: ContentChildren, args: [DynamicTemplateDirective] }], klass: [{ type: HostBinding, args: ["class"] }], asBootstrapFormGroup: [{ type: Input }], context: [{ type: Input }], group: [{ type: Input }], hostClass: [{ type: Input }], inputTemplateList: [{ type: Input, args: ["templates"] }], layout: [{ type: Input }], model: [{ type: Input }], blur: [{ type: Output }], change: [{ type: Output }], focus: [{ type: Output }], customEvent: [{ type: Output, args: ["bsEvent"] }], componentViewContainerRef: [{ type: ViewChild, args: ["componentViewContainer", { read: ViewContainerRef, static: true }] }] } }); export function bootstrapUIFormControlMapFn(model) { switch (model.type) { case DYNAMIC_FORM_CONTROL_TYPE_ARRAY: return DynamicBootstrapFormArrayComponent; case DYNAMIC_FORM_CONTROL_TYPE_CHECKBOX: return DynamicBootstrapCheckboxComponent; case DYNAMIC_FORM_CONTROL_TYPE_CHECKBOX_GROUP: return DynamicBootstrapFormGroupComponent; case DYNAMIC_FORM_CONTROL_TYPE_DATEPICKER: return DynamicBootstrapDatePickerComponent; case DYNAMIC_FORM_CONTROL_TYPE_GROUP: return DynamicBootstrapFormGroupComponent; case DYNAMIC_FORM_CONTROL_TYPE_INPUT: return DynamicBootstrapInputComponent; case DYNAMIC_FORM_CONTROL_TYPE_RADIO_GROUP: return DynamicBootstrapRadioGroupComponent; case DYNAMIC_FORM_CONTROL_TYPE_RATING: return DynamicBootstrapRatingComponent; case DYNAMIC_FORM_CONTROL_TYPE_SELECT: return DynamicBootstrapSelectComponent; case DYNAMIC_FORM_CONTROL_TYPE_TEXTAREA: return DynamicBootstrapTextAreaComponent; case DYNAMIC_FORM_CONTROL_TYPE_TIMEPICKER: return DynamicBootstrapTimePickerComponent; default: return null; } } export class DynamicBootstrapFormArrayComponent extends DynamicFormArrayComponent { constructor(layoutService, validationService) { super(layoutService, validationService); this.layoutService = layoutService; this.validationService = validationService; this.blur = new EventEmitter(); this.change = new EventEmitter(); this.customEvent = new EventEmitter(); this.focus = new EventEmitter(); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: DynamicBootstrapFormArrayComponent, deps: [{ token: i1.DynamicFormLayoutService }, { token: i1.DynamicFormValidationService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.3", type: DynamicBootstrapFormArrayComponent, isStandalone: true, selector: "dynamic-bootstrap-form-array", inputs: { formLayout: "formLayout", group: "group", layout: "layout", model: "model", templates: "templates" }, outputs: { blur: "blur", change: "change", customEvent: "customEvent", focus: "focus" }, viewQueries: [{ propertyName: "components", predicate: DynamicBootstrapFormControlContainerComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-container [formGroup]=\"group\">\n\n <div [formArrayName]=\"model.id\" [id]=\"id\" [ngClass]=\"getClass('element', 'control')\">\n\n <div *ngFor=\"let groupModel of model.groups; let idx = index\" role=\"group\"\n [formGroupName]=\"idx\" [ngClass]=\"[getClass('element', 'group'), getClass('grid', 'group')]\">\n\n <ng-container *ngTemplateOutlet=\"startTemplate?.templateRef; context: groupModel\"></ng-container>\n\n <dynamic-bootstrap-form-control *ngFor=\"let _model of groupModel.group\"\n [context]=\"groupModel\"\n [group]=\"array.at(idx)\"\n [hidden]=\"_model.hidden\"\n [layout]=\"formLayout\"\n [model]=\"_model\"\n [templates]=\"templates\"\n [hostClass]=\"[getClass('element','children'), getClass('grid','children')]\"\n (blur)=\"onBlur($event)\"\n (change)=\"onChange($event)\"\n (focus)=\"onFocus($event)\"\n (bsEvent)=\"onCustomEvent($event, null, true)\"></dynamic-bootstrap-form-control>\n\n <ng-container *ngTemplateOutlet=\"endTemplate?.templateRef; context: groupModel\"></ng-container>\n\n </div>\n\n </div>\n\n</ng-container>\n", dependencies: [{ kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { kind: "directive", type: i2.FormArrayName, selector: "[formArrayName]", inputs: ["formArrayName"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: DynamicBootstrapFormControlContainerComponent, selector: "dynamic-bootstrap-form-control", inputs: ["asBootstrapFormGroup", "context", "group", "hostClass", "templates", "layout", "model"], outputs: ["blur", "change", "focus", "bsEvent"] }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: DynamicBootstrapFormArrayComponent, decorators: [{ type: Component, args: [{ selector: "dynamic-bootstrap-form-array", standalone: true, imports: [ReactiveFormsModule, NgClass, NgFor, NgTemplateOutlet, DynamicBootstrapFormControlContainerComponent], template: "<ng-container [formGroup]=\"group\">\n\n <div [formArrayName]=\"model.id\" [id]=\"id\" [ngClass]=\"getClass('element', 'control')\">\n\n <div *ngFor=\"let groupModel of model.groups; let idx = index\" role=\"group\"\n [formGroupName]=\"idx\" [ngClass]=\"[getClass('element', 'group'), getClass('grid', 'group')]\">\n\n <ng-container *ngTemplateOutlet=\"startTemplate?.templateRef; context: groupModel\"></ng-container>\n\n <dynamic-bootstrap-form-control *ngFor=\"let _model of groupModel.group\"\n [context]=\"groupModel\"\n [group]=\"array.at(idx)\"\n [hidden]=\"_model.hidden\"\n [layout]=\"formLayout\"\n [model]=\"_model\"\n [templates]=\"templates\"\n [hostClass]=\"[getClass('element','children'), getClass('grid','children')]\"\n (blur)=\"onBlur($event)\"\n (change)=\"onChange($event)\"\n (focus)=\"onFocus($event)\"\n (bsEvent)=\"onCustomEvent($event, null, true)\"></dynamic-bootstrap-form-control>\n\n <ng-container *ngTemplateOutlet=\"endTemplate?.templateRef; context: groupModel\"></ng-container>\n\n </div>\n\n </div>\n\n</ng-container>\n" }] }], ctorParameters: function () { return [{ type: i1.DynamicFormLayoutService }, { type: i1.DynamicFormValidationService }]; }, propDecorators: { formLayout: [{ type: Input }], group: [{ type: Input }], layout: [{ type: Input }], model: [{ type: Input }], templates: [{ type: Input }], blur: [{ type: Output }], change: [{ type: Output }], customEvent: [{ type: Output }], focus: [{ type: Output }], components: [{ type: ViewChildren, args: [DynamicBootstrapFormControlContainerComponent] }] } }); export class DynamicBootstrapFormGroupComponent extends DynamicFormGroupComponent { constructor(layoutService, validationService) { super(layoutService, validationService); this.layoutService = layoutService; this.validationService = validationService; this.blur = new EventEmitter(); this.change = new EventEmitter(); this.customEvent = new EventEmitter(); this.focus = new EventEmitter(); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: DynamicBootstrapFormGroupComponent, deps: [{ token: i1.DynamicFormLayoutService }, { token: i1.DynamicFormValidationService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.3", type: DynamicBootstrapFormGroupComponent, isStandalone: true, selector: "dynamic-bootstrap-form-group", inputs: { formLayout: "formLayout", group: "group", layout: "layout", model: "model", templates: "templates" }, outputs: { blur: "blur", change: "change", customEvent: "customEvent", focus: "focus" }, viewQueries: [{ propertyName: "components", predicate: DynamicBootstrapFormControlContainerComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-container [formGroup]=\"group\">\n\n <fieldset [formGroupName]=\"model.id\"\n [id]=\"id\"\n [name]=\"model.name\"\n [ngClass]=\"getClass('element', 'control')\">\n\n <legend *ngIf=\"model.legend\" [innerHTML]=\"model.legend\"></legend>\n\n <dynamic-bootstrap-form-control *ngFor=\"let _model of model.group\"\n [asBootstrapFormGroup]=\"false\"\n [group]=\"control\"\n [hidden]=\"_model.hidden\"\n [layout]=\"formLayout\"\n [model]=\"_model\"\n [templates]=\"templates\"\n [hostClass]=\"[getClass('element','children'), getClass('grid','children')]\"\n (blur)=\"onBlur($event)\"\n (change)=\"onChange($event)\"\n (focus)=\"onFocus($event)\"\n (bsEvent)=\"onCustomEvent($event, null, true)\"></dynamic-bootstrap-form-control>\n </fieldset>\n\n</ng-container>\n", dependencies: [{ kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: DynamicBootstrapFormControlContainerComponent, selector: "dynamic-bootstrap-form-control", inputs: ["asBootstrapFormGroup", "context", "group", "hostClass", "templates", "layout", "model"], outputs: ["blur", "change", "focus", "bsEvent"] }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: DynamicBootstrapFormGroupComponent, decorators: [{ type: Component, args: [{ selector: "dynamic-bootstrap-form-group", standalone: true, imports: [ReactiveFormsModule, NgClass, NgIf, NgFor, DynamicBootstrapFormControlContainerComponent], template: "<ng-container [formGroup]=\"group\">\n\n <fieldset [formGroupName]=\"model.id\"\n [id]=\"id\"\n [name]=\"model.name\"\n [ngClass]=\"getClass('element', 'control')\">\n\n <legend *ngIf=\"model.legend\" [innerHTML]=\"model.legend\"></legend>\n\n <dynamic-bootstrap-form-control *ngFor=\"let _model of model.group\"\n [asBootstrapFormGroup]=\"false\"\n [group]=\"control\"\n [hidden]=\"_model.hidden\"\n [layout]=\"formLayout\"\n [model]=\"_model\"\n [templates]=\"templates\"\n [hostClass]=\"[getClass('element','children'), getClass('grid','children')]\"\n (blur)=\"onBlur($event)\"\n (change)=\"onChange($event)\"\n (focus)=\"onFocus($event)\"\n (bsEvent)=\"onCustomEvent($event, null, true)\"></dynamic-bootstrap-form-control>\n </fieldset>\n\n</ng-container>\n" }] }], ctorParameters: function () { return [{ type: i1.DynamicFormLayoutService }, { type: i1.DynamicFormValidationService }]; }, propDecorators: { formLayout: [{ type: Input }], group: [{ type: Input }], layout: [{ type: Input }], model: [{ type: Input }], templates: [{ type: Input }], blur: [{ type: Output }], change: [{ type: Output }], customEvent: [{ type: Output }], focus: [{ type: Output }], components: [{ type: ViewChildren, args: [DynamicBootstrapFormControlContainerComponent] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-bootstrap-form-control-container.component.js","sourceRoot":"","sources":["../../../../../projects/ng-dynamic-forms/ui-bootstrap/src/lib/dynamic-bootstrap-form-control-container.component.ts","../../../../../projects/ng-dynamic-forms/ui-bootstrap/src/lib/dynamic-bootstrap-form-control-container.component.html","../../../../../projects/ng-dynamic-forms/ui-bootstrap/src/lib/dynamic-bootstrap-form-array.component.html","../../../../../projects/ng-dynamic-forms/ui-bootstrap/src/lib/dynamic-bootstrap-form-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ComponentFactoryResolver,\n    ContentChildren,\n    EventEmitter,\n    HostBinding,\n    Input,\n    Output,\n    QueryList,\n    Type,\n    ViewChild,\n    ViewChildren,\n    ViewContainerRef\n} from \"@angular/core\";\nimport { UntypedFormGroup, ReactiveFormsModule } from \"@angular/forms\";\nimport {\n    DYNAMIC_FORM_CONTROL_TYPE_ARRAY,\n    DYNAMIC_FORM_CONTROL_TYPE_CHECKBOX,\n    DYNAMIC_FORM_CONTROL_TYPE_CHECKBOX_GROUP,\n    DYNAMIC_FORM_CONTROL_TYPE_DATEPICKER,\n    DYNAMIC_FORM_CONTROL_TYPE_GROUP,\n    DYNAMIC_FORM_CONTROL_TYPE_INPUT,\n    DYNAMIC_FORM_CONTROL_TYPE_RADIO_GROUP,\n    DYNAMIC_FORM_CONTROL_TYPE_RATING,\n    DYNAMIC_FORM_CONTROL_TYPE_SELECT,\n    DYNAMIC_FORM_CONTROL_TYPE_TEXTAREA,\n    DYNAMIC_FORM_CONTROL_TYPE_TIMEPICKER,\n    DynamicFormArrayGroupModel,\n    DynamicFormControl,\n    DynamicFormControlContainerComponent,\n    DynamicFormControlEvent,\n    DynamicFormControlModel,\n    DynamicFormComponentService,\n    DynamicFormLayout,\n    DynamicFormLayoutService,\n    DynamicFormRelationService,\n    DynamicFormValidationService,\n    DynamicTemplateDirective,\n    DynamicFormArrayComponent,\n    DynamicFormControlLayout,\n    DynamicFormArrayModel,\n    DynamicFormControlCustomEvent,\n    DynamicFormGroupComponent,\n    DynamicFormGroupModel\n} from \"@ng-dynamic-forms/core\";\nimport { DynamicBootstrapCheckboxComponent } from \"./checkbox/dynamic-bootstrap-checkbox.component\";\nimport { DynamicBootstrapDatePickerComponent } from \"./datepicker/dynamic-bootstrap-datepicker.component\";\nimport { DynamicBootstrapInputComponent } from \"./input/dynamic-bootstrap-input.component\";\nimport { DynamicBootstrapRadioGroupComponent } from \"./radio-group/dynamic-bootstrap-radio-group.component\";\nimport { DynamicBootstrapRatingComponent } from \"./rating/dynamic-bootstrap-rating.component\";\nimport { DynamicBootstrapSelectComponent } from \"./select/dynamic-bootstrap-select.component\";\nimport { DynamicBootstrapTextAreaComponent } from \"./textarea/dynamic-bootstrap-textarea.component\";\nimport { DynamicBootstrapTimePickerComponent } from \"./timepicker/dynamic-bootstrap-timepicker.component\";\nimport { NgClass, NgFor, NgTemplateOutlet, NgIf } from \"@angular/common\";\n\n@Component({\n    selector: \"dynamic-bootstrap-form-control\",\n    templateUrl: \"./dynamic-bootstrap-form-control-container.component.html\",\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [ReactiveFormsModule, NgClass, NgIf, NgTemplateOutlet, NgFor]\n})\nexport class DynamicBootstrapFormControlContainerComponent extends DynamicFormControlContainerComponent {\n    @ContentChildren(DynamicTemplateDirective) contentTemplateList!: QueryList<DynamicTemplateDirective>;\n\n    @HostBinding(\"class\") klass?: string;\n\n    @Input() asBootstrapFormGroup = true;\n    @Input() context: DynamicFormArrayGroupModel | null = null;\n    @Input() group!: UntypedFormGroup;\n    @Input() hostClass?: string[];\n    // tslint:disable-next-line:no-input-rename\n    @Input(\"templates\") inputTemplateList?: QueryList<DynamicTemplateDirective>;\n    @Input() layout?: DynamicFormLayout;\n    @Input() model!: DynamicFormControlModel;\n\n    @Output() blur: EventEmitter<DynamicFormControlEvent> = new EventEmitter<DynamicFormControlEvent>();\n    @Output() change: EventEmitter<DynamicFormControlEvent> = new EventEmitter<DynamicFormControlEvent>();\n    @Output() focus: EventEmitter<DynamicFormControlEvent> = new EventEmitter<DynamicFormControlEvent>();\n    // tslint:disable-next-line:no-output-rename\n    @Output(\"bsEvent\") customEvent: EventEmitter<DynamicFormControlEvent> = new EventEmitter<DynamicFormControlEvent>();\n\n    @ViewChild(\"componentViewContainer\", {read: ViewContainerRef, static: true}) componentViewContainerRef!: ViewContainerRef;\n\n    get componentType(): Type<DynamicFormControl> | null {\n        return this.componentService.getCustomComponentType(this.model) || bootstrapUIFormControlMapFn(this.model);\n    }\n\n    constructor(protected changeDetectorRef: ChangeDetectorRef,\n                protected componentFactoryResolver: ComponentFactoryResolver,\n                protected layoutService: DynamicFormLayoutService,\n                protected validationService: DynamicFormValidationService,\n                protected componentService: DynamicFormComponentService,\n                protected relationService: DynamicFormRelationService) {\n        super(changeDetectorRef, componentFactoryResolver, layoutService, validationService, componentService, relationService);\n    }\n}\n\nexport function bootstrapUIFormControlMapFn(model: DynamicFormControlModel): Type<DynamicFormControl> | null {\n    switch (model.type) {\n        case DYNAMIC_FORM_CONTROL_TYPE_ARRAY:\n            return DynamicBootstrapFormArrayComponent;\n\n        case DYNAMIC_FORM_CONTROL_TYPE_CHECKBOX:\n            return DynamicBootstrapCheckboxComponent;\n\n        case DYNAMIC_FORM_CONTROL_TYPE_CHECKBOX_GROUP:\n            return DynamicBootstrapFormGroupComponent;\n\n        case DYNAMIC_FORM_CONTROL_TYPE_DATEPICKER:\n            return DynamicBootstrapDatePickerComponent;\n\n        case DYNAMIC_FORM_CONTROL_TYPE_GROUP:\n            return DynamicBootstrapFormGroupComponent;\n\n        case DYNAMIC_FORM_CONTROL_TYPE_INPUT:\n            return DynamicBootstrapInputComponent;\n\n        case DYNAMIC_FORM_CONTROL_TYPE_RADIO_GROUP:\n            return DynamicBootstrapRadioGroupComponent;\n\n        case DYNAMIC_FORM_CONTROL_TYPE_RATING:\n            return DynamicBootstrapRatingComponent;\n\n        case DYNAMIC_FORM_CONTROL_TYPE_SELECT:\n            return DynamicBootstrapSelectComponent;\n\n        case DYNAMIC_FORM_CONTROL_TYPE_TEXTAREA:\n            return DynamicBootstrapTextAreaComponent;\n\n        case DYNAMIC_FORM_CONTROL_TYPE_TIMEPICKER:\n            return DynamicBootstrapTimePickerComponent;\n\n        default:\n            return null;\n    }\n}\n\n@Component({\n    selector: \"dynamic-bootstrap-form-array\",\n    templateUrl: \"./dynamic-bootstrap-form-array.component.html\",\n    standalone: true,\n    imports: [ReactiveFormsModule, NgClass, NgFor, NgTemplateOutlet, DynamicBootstrapFormControlContainerComponent]\n})\nexport class DynamicBootstrapFormArrayComponent extends DynamicFormArrayComponent {\n    @Input() formLayout?: DynamicFormLayout;\n    @Input() group!: UntypedFormGroup;\n    @Input() layout?: DynamicFormControlLayout;\n    @Input() model!: DynamicFormArrayModel;\n    @Input() templates?: QueryList<DynamicTemplateDirective>;\n\n    @Output() blur: EventEmitter<any> = new EventEmitter();\n    @Output() change: EventEmitter<any> = new EventEmitter();\n    @Output() customEvent: EventEmitter<DynamicFormControlCustomEvent> = new EventEmitter();\n    @Output() focus: EventEmitter<any> = new EventEmitter();\n\n    @ViewChildren(DynamicBootstrapFormControlContainerComponent) components!: QueryList<DynamicBootstrapFormControlContainerComponent>;\n\n    constructor(protected layoutService: DynamicFormLayoutService, protected validationService: DynamicFormValidationService) {\n        super(layoutService, validationService);\n    }\n}\n\n@Component({\n    selector: \"dynamic-bootstrap-form-group\",\n    templateUrl: \"./dynamic-bootstrap-form-group.component.html\",\n    standalone: true,\n    imports: [ReactiveFormsModule, NgClass, NgIf, NgFor, DynamicBootstrapFormControlContainerComponent]\n})\nexport class DynamicBootstrapFormGroupComponent extends DynamicFormGroupComponent {\n    @Input() formLayout?: DynamicFormLayout;\n    @Input() group!: UntypedFormGroup;\n    @Input() layout?: DynamicFormControlLayout;\n    @Input() model!: DynamicFormGroupModel;\n    @Input() templates?: QueryList<DynamicTemplateDirective> | DynamicTemplateDirective[];\n\n    @Output() blur: EventEmitter<any> = new EventEmitter();\n    @Output() change: EventEmitter<any> = new EventEmitter();\n    @Output() customEvent: EventEmitter<DynamicFormControlCustomEvent> = new EventEmitter();\n    @Output() focus: EventEmitter<any> = new EventEmitter();\n\n    @ViewChildren(DynamicBootstrapFormControlContainerComponent) components!: QueryList<DynamicBootstrapFormControlContainerComponent>;\n\n    constructor(protected layoutService: DynamicFormLayoutService, protected validationService: DynamicFormValidationService) {\n        super(layoutService, validationService);\n    }\n}\n","<div [class.form-group]=\"asBootstrapFormGroup || getClass('element', 'container').includes('form-group')\"\n     [class.has-error]=\"showErrorMessages\"\n     [formGroup]=\"group\"\n     [ngClass]=\"['ng-dynamic-forms-'+model.type.toLowerCase(), getClass('element', 'container'), getClass('grid', 'container')]\">\n\n    <label *ngIf=\"!isCheckbox && hasLabel\"\n           [for]=\"id\"\n           [innerHTML]=\"model.label\"\n           [ngClass]=\"[getClass('element', 'label'), getClass('grid', 'label')]\"></label>\n\n    <ng-container *ngTemplateOutlet=\"startTemplate?.templateRef; context: model\"></ng-container>\n\n    <div [ngClass]=\"getClass('grid', 'control')\">\n\n        <ng-container #componentViewContainer></ng-container>\n\n        <span *ngIf=\"hasHint\" class=\"help-block\" [innerHTML]=\"hint\"\n              [ngClass]=\"getClass('element', 'hint')\"></span>\n\n    </div>\n\n    <ul *ngIf=\"showErrorMessages\" class=\"has-error\"\n        [ngClass]=\"[getClass('element', 'errors'), getClass('grid', 'errors')]\">\n\n        <li *ngFor=\"let message of errorMessages\" class=\"help-block\">{{ message }}</li>\n\n    </ul>\n\n    <ng-container *ngTemplateOutlet=\"endTemplate?.templateRef; context: model\"></ng-container>\n\n    <ng-content></ng-content>\n\n</div>\n","<ng-container [formGroup]=\"group\">\n\n    <div [formArrayName]=\"model.id\" [id]=\"id\" [ngClass]=\"getClass('element', 'control')\">\n\n        <div *ngFor=\"let groupModel of model.groups; let idx = index\" role=\"group\"\n             [formGroupName]=\"idx\" [ngClass]=\"[getClass('element', 'group'), getClass('grid', 'group')]\">\n\n            <ng-container *ngTemplateOutlet=\"startTemplate?.templateRef; context: groupModel\"></ng-container>\n\n            <dynamic-bootstrap-form-control *ngFor=\"let _model of groupModel.group\"\n                                            [context]=\"groupModel\"\n                                            [group]=\"array.at(idx)\"\n                                            [hidden]=\"_model.hidden\"\n                                            [layout]=\"formLayout\"\n                                            [model]=\"_model\"\n                                            [templates]=\"templates\"\n                                            [hostClass]=\"[getClass('element','children'), getClass('grid','children')]\"\n                                            (blur)=\"onBlur($event)\"\n                                            (change)=\"onChange($event)\"\n                                            (focus)=\"onFocus($event)\"\n                                            (bsEvent)=\"onCustomEvent($event, null, true)\"></dynamic-bootstrap-form-control>\n\n            <ng-container *ngTemplateOutlet=\"endTemplate?.templateRef; context: groupModel\"></ng-container>\n\n        </div>\n\n    </div>\n\n</ng-container>\n","<ng-container [formGroup]=\"group\">\n\n    <fieldset [formGroupName]=\"model.id\"\n              [id]=\"id\"\n              [name]=\"model.name\"\n              [ngClass]=\"getClass('element', 'control')\">\n\n        <legend *ngIf=\"model.legend\" [innerHTML]=\"model.legend\"></legend>\n\n        <dynamic-bootstrap-form-control *ngFor=\"let _model of model.group\"\n                                        [asBootstrapFormGroup]=\"false\"\n                                        [group]=\"control\"\n                                        [hidden]=\"_model.hidden\"\n                                        [layout]=\"formLayout\"\n                                        [model]=\"_model\"\n                                        [templates]=\"templates\"\n                                        [hostClass]=\"[getClass('element','children'), getClass('grid','children')]\"\n                                        (blur)=\"onBlur($event)\"\n                                        (change)=\"onChange($event)\"\n                                        (focus)=\"onFocus($event)\"\n                                        (bsEvent)=\"onCustomEvent($event, null, true)\"></dynamic-bootstrap-form-control>\n    </fieldset>\n\n</ng-container>\n"]}