@ng-dynamic-forms/core
Version:
A rapid form development library for Angular
247 lines • 43.3 kB
JavaScript
import { Directive } from "@angular/core";
import { DynamicFormControlEventType, isDynamicFormControlEvent } from "./dynamic-form-control-event";
import { DynamicFormValueControlModel } from "../model/dynamic-form-value-control.model";
import { DYNAMIC_FORM_CONTROL_TYPE_ARRAY, DynamicFormArrayGroupModel } from "../model/form-array/dynamic-form-array.model";
import { DYNAMIC_FORM_CONTROL_TYPE_CHECKBOX } from "../model/checkbox/dynamic-checkbox.model";
import { DYNAMIC_FORM_CONTROL_INPUT_TYPE_FILE, DYNAMIC_FORM_CONTROL_TYPE_INPUT } from "../model/input/dynamic-input.model";
import { isString } from "../utils/core.utils";
import { DynamicFormGroupComponent } from "./dynamic-form-group.component";
import { DynamicFormArrayComponent } from "./dynamic-form-array.component";
import { bufferCount, filter, map } from "rxjs/operators";
import * as i0 from "@angular/core";
import * as i1 from "../service/dynamic-form-layout.service";
import * as i2 from "../service/dynamic-form-validation.service";
import * as i3 from "../service/dynamic-form-component.service";
import * as i4 from "../service/dynamic-form-relation.service";
// tslint:disable-next-line:directive-class-suffix
export class DynamicFormControlContainerComponent {
constructor(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._hasFocus = false;
this.context = null;
this.componentSubscriptions = [];
this.subscriptions = [];
}
ngOnChanges(changes) {
const groupChange = changes.group;
const layoutChange = changes.layout;
const modelChange = changes.model;
if (layoutChange || modelChange) {
this.onLayoutOrModelChange();
}
if (modelChange) {
this.onModelChange();
}
if (groupChange || modelChange) {
this.onGroupOrModelChange();
}
}
ngOnInit() {
this.subscriptions.push(this.control.statusChanges.pipe(bufferCount(2, 1), map(states => states[0]), filter(previousState => previousState === "PENDING")).subscribe(_status => this.markForCheck()));
}
ngOnDestroy() {
this.destroyFormControlComponent();
this.unsubscribe();
}
get id() {
return this.layoutService.getElementId(this.model);
}
get hasFocus() {
return this._hasFocus;
}
get isInvalid() {
return this.control.invalid;
}
get isValid() {
return this.control.valid;
}
get errorMessages() {
return this.validationService.createErrorMessages(this.control, this.model);
}
get showErrorMessages() {
return this.validationService.showErrorMessages(this.control, this.model, this.hasFocus);
}
get hasLabel() {
return isString(this.model.label);
}
get hasHint() {
return isString(this.model.hint);
}
get hint() {
return this.model.hint ?? null;
}
get isCheckbox() {
return this.model.type === DYNAMIC_FORM_CONTROL_TYPE_CHECKBOX;
}
get templates() {
return this.inputTemplateList !== undefined ? this.inputTemplateList : this.contentTemplateList;
}
get startTemplate() {
return this.model.type !== DYNAMIC_FORM_CONTROL_TYPE_ARRAY ?
this.layoutService.getStartTemplate(this.model, this.templates) : undefined;
}
get endTemplate() {
return this.model.type !== DYNAMIC_FORM_CONTROL_TYPE_ARRAY ?
this.layoutService.getEndTemplate(this.model, this.templates) : undefined;
}
getClass(context, place) {
return this.layoutService.getClass(this.controlLayout, context, place);
}
markForCheck() {
this.changeDetectorRef.markForCheck();
const component = this.componentRef && this.componentRef.instance;
if (component && (component instanceof DynamicFormGroupComponent || component instanceof DynamicFormArrayComponent)) {
component.markForCheck();
}
}
createFormControlComponent() {
const componentType = this.componentType;
if (componentType !== null) {
const componentFactory = this.componentFactoryResolver.resolveComponentFactory(componentType);
this.componentViewContainerRef.clear();
this.componentRef = this.componentViewContainerRef.createComponent(componentFactory);
const component = this.componentRef.instance;
component.formLayout = this.layout;
component.group = this.group;
component.layout = this.controlLayout;
component.model = this.model;
if (this.templates) {
component.templates = this.templates;
}
this.componentSubscriptions.push(component.blur.subscribe(($event) => this.onBlur($event)));
this.componentSubscriptions.push(component.change.subscribe(($event) => this.onChange($event)));
this.componentSubscriptions.push(component.focus.subscribe(($event) => this.onFocus($event)));
if (component.customEvent !== undefined) {
this.componentSubscriptions.push(component.customEvent.subscribe(($event) => this.onCustomEvent($event)));
}
this.registerFormControlComponentRef(this.componentRef);
}
}
destroyFormControlComponent() {
if (this.componentRef) {
this.componentSubscriptions.forEach(subscription => subscription.unsubscribe());
this.componentSubscriptions = [];
this.unregisterFormControlComponentRef();
this.componentRef.destroy();
}
}
createDynamicFormControlEvent($event, type) {
return { $event, context: this.context, control: this.control, group: this.group, model: this.model, type };
}
unsubscribe() {
// this.componentSubscriptions.forEach(subscription => subscription.unsubscribe());
// this.componentSubscriptions = [];
this.subscriptions.forEach(subscription => subscription.unsubscribe());
this.subscriptions = [];
}
onControlValueChanges(value) {
if (this.model instanceof DynamicFormValueControlModel && this.model.value !== value) {
this.model.value = value;
}
}
onModelValueUpdates(value) {
if (this.control.value !== value) {
this.control.setValue(value);
}
}
onModelDisabledUpdates(disabled) {
disabled ? this.control.disable() : this.control.enable();
}
onLayoutOrModelChange() {
this.controlLayout = this.layoutService.findByModel(this.model, this.layout) ?? this.model.layout;
this.klass = `${Array.isArray(this.hostClass) ? this.hostClass.join(" ") : ""} ${this.layoutService.getHostClass(this.controlLayout)}`;
}
onModelChange() {
this.destroyFormControlComponent();
this.createFormControlComponent();
}
onGroupOrModelChange() {
if (this.model) {
this.unsubscribe();
if (this.group) {
this.control = this.group.get(this.model.id);
this.subscriptions.push(this.control.valueChanges.subscribe(value => this.onControlValueChanges(value)));
}
this.subscriptions.push(this.model.disabledChanges.subscribe(value => this.onModelDisabledUpdates(value)));
if (this.model instanceof DynamicFormValueControlModel) {
const model = this.model;
this.subscriptions.push(model.valueChanges.subscribe(value => this.onModelValueUpdates(value)));
}
if (this.model.relations.length > 0) {
this.subscriptions.push(...this.relationService.subscribeRelations(this.model, this.group, this.control));
}
}
}
onChange($event) {
if ($event instanceof Event) { // native HTML5 change event
if (this.model.type === DYNAMIC_FORM_CONTROL_TYPE_INPUT) {
const model = this.model;
if (model.inputType === DYNAMIC_FORM_CONTROL_INPUT_TYPE_FILE) {
const inputElement = $event.target;
model.files = inputElement.files;
}
}
this.change.emit(this.createDynamicFormControlEvent($event, DynamicFormControlEventType.Change));
}
else if (isDynamicFormControlEvent($event)) { // event bypass
this.change.emit($event);
}
else { // custom library value change event
this.change.emit(this.createDynamicFormControlEvent($event, DynamicFormControlEventType.Change));
}
}
onBlur($event) {
if (isDynamicFormControlEvent($event)) { // event bypass
this.blur.emit($event);
}
else { // native HTML 5 or UI library blur event
this._hasFocus = false;
this.blur.emit(this.createDynamicFormControlEvent($event, DynamicFormControlEventType.Blur));
}
}
onFocus($event) {
if (isDynamicFormControlEvent($event)) { // event bypass
this.focus.emit($event);
}
else { // native HTML 5 or UI library focus event
this._hasFocus = true;
this.focus.emit(this.createDynamicFormControlEvent($event, DynamicFormControlEventType.Focus));
}
}
onCustomEvent($event) {
const emitter = this.customEvent;
if (isDynamicFormControlEvent($event)) { // child event bypass
emitter.emit($event);
}
else { // native UI library custom event
emitter.emit(this.createDynamicFormControlEvent($event.customEvent, $event.customEventType));
}
}
registerFormControlComponentRef(ref) {
if (this.context instanceof DynamicFormArrayGroupModel) {
this.componentService.registerFormControl(this.model, ref, this.context.index);
}
else {
this.componentService.registerFormControl(this.model, ref);
}
}
unregisterFormControlComponentRef() {
if (this.context instanceof DynamicFormArrayGroupModel) {
this.componentService.unregisterFormControl(this.model.id, this.context.index);
}
else {
this.componentService.unregisterFormControl(this.model.id);
}
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: DynamicFormControlContainerComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ComponentFactoryResolver }, { token: i1.DynamicFormLayoutService }, { token: i2.DynamicFormValidationService }, { token: i3.DynamicFormComponentService }, { token: i4.DynamicFormRelationService }], target: i0.ɵɵFactoryTarget.Directive }); }
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.3", type: DynamicFormControlContainerComponent, usesOnChanges: true, ngImport: i0 }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: DynamicFormControlContainerComponent, decorators: [{
type: Directive
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ComponentFactoryResolver }, { type: i1.DynamicFormLayoutService }, { type: i2.DynamicFormValidationService }, { type: i3.DynamicFormComponentService }, { type: i4.DynamicFormRelationService }]; } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form-control-container.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-dynamic-forms/core/src/lib/component/dynamic-form-control-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectorRef,\n    ComponentFactoryResolver,\n    ComponentRef, Directive,\n    EventEmitter,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    QueryList,\n    SimpleChanges,\n    Type,\n    ViewContainerRef\n} from \"@angular/core\";\nimport { UntypedFormControl, UntypedFormGroup } from \"@angular/forms\";\nimport { Subscription } from \"rxjs\";\nimport {\n    DynamicFormControlCustomEvent,\n    DynamicFormControlEvent,\n    DynamicFormControlEventType,\n    isDynamicFormControlEvent\n} from \"./dynamic-form-control-event\";\nimport { DynamicFormControlModel } from \"../model/dynamic-form-control.model\";\nimport { DynamicFormValueControlModel } from \"../model/dynamic-form-value-control.model\";\nimport {\n    DYNAMIC_FORM_CONTROL_TYPE_ARRAY,\n    DynamicFormArrayGroupModel\n} from \"../model/form-array/dynamic-form-array.model\";\nimport { DYNAMIC_FORM_CONTROL_TYPE_CHECKBOX } from \"../model/checkbox/dynamic-checkbox.model\";\nimport {\n    DYNAMIC_FORM_CONTROL_INPUT_TYPE_FILE,\n    DYNAMIC_FORM_CONTROL_TYPE_INPUT,\n    DynamicInputModel\n} from \"../model/input/dynamic-input.model\";\nimport {\n    DynamicFormControlLayout,\n    DynamicFormControlLayoutContext,\n    DynamicFormControlLayoutPlace\n} from \"../model/misc/dynamic-form-control-layout.model\";\nimport { DynamicFormControl } from \"./dynamic-form-control-interface\";\nimport { DynamicTemplateDirective } from \"../directive/dynamic-template.directive\";\nimport { DynamicFormLayout, DynamicFormLayoutService } from \"../service/dynamic-form-layout.service\";\nimport { DynamicFormValidationService } from \"../service/dynamic-form-validation.service\";\nimport { DynamicFormComponentService } from \"../service/dynamic-form-component.service\";\nimport { isString } from \"../utils/core.utils\";\nimport { DynamicFormRelationService } from \"../service/dynamic-form-relation.service\";\nimport { DynamicFormGroupComponent } from \"./dynamic-form-group.component\";\nimport { DynamicFormArrayComponent } from \"./dynamic-form-array.component\";\nimport { bufferCount, filter, map } from \"rxjs/operators\";\n\n@Directive()\n// tslint:disable-next-line:directive-class-suffix\nexport abstract class DynamicFormControlContainerComponent implements OnChanges, OnInit, OnDestroy {\n    private _hasFocus = false;\n\n    context: DynamicFormArrayGroupModel | null = null;\n    control!: UntypedFormControl;\n    group!: UntypedFormGroup;\n    hostClass?: string[];\n    klass?: string;\n    layout?: DynamicFormLayout;\n    model!: DynamicFormControlModel;\n\n    contentTemplateList?: QueryList<DynamicTemplateDirective>;\n    inputTemplateList?: QueryList<DynamicTemplateDirective>;\n\n    blur!: EventEmitter<DynamicFormControlEvent>;\n    change!: EventEmitter<DynamicFormControlEvent>;\n    customEvent?: EventEmitter<DynamicFormControlEvent>;\n    focus!: EventEmitter<DynamicFormControlEvent>;\n\n    componentViewContainerRef!: ViewContainerRef;\n\n    protected componentRef!: ComponentRef<DynamicFormControl>;\n    protected componentSubscriptions: Subscription[] = [];\n    protected controlLayout?: DynamicFormControlLayout;\n    protected subscriptions: Subscription[] = [];\n\n    protected 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    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        const groupChange = (changes as Pick<SimpleChanges, \"group\">).group;\n        const layoutChange = (changes as Pick<SimpleChanges, \"layout\">).layout;\n        const modelChange = (changes as Pick<SimpleChanges, \"model\">).model;\n\n        if (layoutChange || modelChange) {\n            this.onLayoutOrModelChange();\n        }\n\n        if (modelChange) {\n            this.onModelChange();\n        }\n\n        if (groupChange || modelChange) {\n            this.onGroupOrModelChange();\n        }\n    }\n\n    ngOnInit(): void {\n        this.subscriptions.push(this.control.statusChanges.pipe(\n            bufferCount(2, 1),\n            map(states => states[0]),\n            filter(previousState => previousState === \"PENDING\")\n        ).subscribe(_status => this.markForCheck()));\n    }\n\n    ngOnDestroy(): void {\n        this.destroyFormControlComponent();\n        this.unsubscribe();\n    }\n\n    abstract get componentType(): Type<DynamicFormControl> | null;\n\n    get id(): string {\n        return this.layoutService.getElementId(this.model);\n    }\n\n    get hasFocus(): boolean {\n        return this._hasFocus;\n    }\n\n    get isInvalid(): boolean {\n        return this.control.invalid;\n    }\n\n    get isValid(): boolean {\n        return this.control.valid;\n    }\n\n    get errorMessages(): string[] {\n        return this.validationService.createErrorMessages(this.control, this.model);\n    }\n\n    get showErrorMessages(): boolean {\n        return this.validationService.showErrorMessages(this.control, this.model, this.hasFocus);\n    }\n\n    get hasLabel(): boolean {\n        return isString(this.model.label);\n    }\n\n    get hasHint(): boolean {\n        return isString((this.model as DynamicFormValueControlModel<any>).hint);\n    }\n\n    get hint(): string | null {\n        return (this.model as DynamicFormValueControlModel<any>).hint ?? null;\n    }\n\n    get isCheckbox(): boolean {\n        return this.model.type === DYNAMIC_FORM_CONTROL_TYPE_CHECKBOX;\n    }\n\n    get templates(): QueryList<DynamicTemplateDirective> | undefined {\n        return this.inputTemplateList !== undefined ? this.inputTemplateList : this.contentTemplateList;\n    }\n\n    get startTemplate(): DynamicTemplateDirective | undefined {\n        return this.model.type !== DYNAMIC_FORM_CONTROL_TYPE_ARRAY ?\n            this.layoutService.getStartTemplate(this.model, this.templates) : undefined;\n    }\n\n    get endTemplate(): DynamicTemplateDirective | undefined {\n        return this.model.type !== DYNAMIC_FORM_CONTROL_TYPE_ARRAY ?\n            this.layoutService.getEndTemplate(this.model, this.templates) : undefined;\n    }\n\n    getClass(context: DynamicFormControlLayoutContext, place: DynamicFormControlLayoutPlace): string {\n        return this.layoutService.getClass(this.controlLayout, context, place);\n    }\n\n    markForCheck(): void {\n        this.changeDetectorRef.markForCheck();\n\n        const component = this.componentRef && this.componentRef.instance;\n\n        if (component && (component instanceof DynamicFormGroupComponent || component instanceof DynamicFormArrayComponent)) {\n            component.markForCheck();\n        }\n    }\n\n    protected createFormControlComponent(): void {\n        const componentType = this.componentType;\n\n        if (componentType !== null) {\n            const componentFactory = this.componentFactoryResolver.resolveComponentFactory(componentType);\n\n            this.componentViewContainerRef.clear();\n            this.componentRef = this.componentViewContainerRef.createComponent(componentFactory);\n\n            const component = this.componentRef.instance;\n\n            component.formLayout = this.layout;\n            component.group = this.group;\n            component.layout = this.controlLayout;\n            component.model = this.model;\n\n            if (this.templates) {\n                component.templates = this.templates;\n            }\n\n            this.componentSubscriptions.push(component.blur.subscribe(($event: any) => this.onBlur($event)));\n            this.componentSubscriptions.push(component.change.subscribe(($event: any) => this.onChange($event)));\n            this.componentSubscriptions.push(component.focus.subscribe(($event: any) => this.onFocus($event)));\n\n            if (component.customEvent !== undefined) {\n                this.componentSubscriptions.push(\n                    component.customEvent.subscribe(($event: any) => this.onCustomEvent($event)));\n            }\n\n            this.registerFormControlComponentRef(this.componentRef);\n        }\n    }\n\n    protected destroyFormControlComponent(): void {\n        if (this.componentRef) {\n            this.componentSubscriptions.forEach(subscription => subscription.unsubscribe());\n            this.componentSubscriptions = [];\n\n            this.unregisterFormControlComponentRef();\n            this.componentRef.destroy();\n        }\n    }\n\n    protected createDynamicFormControlEvent($event: any, type: string): DynamicFormControlEvent {\n        return {$event, context: this.context, control: this.control, group: this.group, model: this.model, type};\n    }\n\n    unsubscribe(): void {\n        // this.componentSubscriptions.forEach(subscription => subscription.unsubscribe());\n        // this.componentSubscriptions = [];\n\n        this.subscriptions.forEach(subscription => subscription.unsubscribe());\n        this.subscriptions = [];\n    }\n\n    onControlValueChanges(value: any): void {\n        if (this.model instanceof DynamicFormValueControlModel && this.model.value !== value) {\n            this.model.value = value;\n        }\n    }\n\n    onModelValueUpdates(value: any): void {\n        if (this.control.value !== value) {\n            this.control.setValue(value);\n        }\n    }\n\n    onModelDisabledUpdates(disabled: boolean): void {\n        disabled ? this.control.disable() : this.control.enable();\n    }\n\n    onLayoutOrModelChange(): void {\n        this.controlLayout = this.layoutService.findByModel(this.model, this.layout) ?? this.model.layout as DynamicFormControlLayout;\n        this.klass = `${Array.isArray(this.hostClass) ? this.hostClass.join(\" \") : \"\"} ${this.layoutService.getHostClass(this.controlLayout)}`;\n    }\n\n    onModelChange(): void {\n        this.destroyFormControlComponent();\n        this.createFormControlComponent();\n    }\n\n    onGroupOrModelChange(): void {\n        if (this.model) {\n            this.unsubscribe();\n\n            if (this.group) {\n                this.control = this.group.get(this.model.id) as UntypedFormControl;\n                this.subscriptions.push(this.control.valueChanges.subscribe(value => this.onControlValueChanges(value)));\n            }\n\n            this.subscriptions.push(this.model.disabledChanges.subscribe(value => this.onModelDisabledUpdates(value)));\n\n            if (this.model instanceof DynamicFormValueControlModel) {\n                const model = this.model as DynamicFormValueControlModel<any>;\n\n                this.subscriptions.push(model.valueChanges.subscribe(value => this.onModelValueUpdates(value)));\n            }\n\n            if (this.model.relations.length > 0) {\n                this.subscriptions.push(...this.relationService.subscribeRelations(this.model, this.group, this.control));\n            }\n        }\n    }\n\n    onChange($event: Event | DynamicFormControlEvent | any): void {\n        if ($event instanceof Event) { // native HTML5 change event\n            if (this.model.type === DYNAMIC_FORM_CONTROL_TYPE_INPUT) {\n                const model = this.model as DynamicInputModel;\n\n                if (model.inputType === DYNAMIC_FORM_CONTROL_INPUT_TYPE_FILE) {\n                    const inputElement: any = $event.target;\n\n                    model.files = inputElement.files as FileList;\n                }\n            }\n\n            this.change.emit(this.createDynamicFormControlEvent($event, DynamicFormControlEventType.Change));\n\n        } else if (isDynamicFormControlEvent($event)) { // event bypass\n            this.change.emit($event);\n\n        } else { // custom library value change event\n            this.change.emit(this.createDynamicFormControlEvent($event, DynamicFormControlEventType.Change));\n        }\n    }\n\n    onBlur($event: FocusEvent | DynamicFormControlEvent | any): void {\n        if (isDynamicFormControlEvent($event)) { // event bypass\n            this.blur.emit($event);\n\n        } else { // native HTML 5 or UI library blur event\n            this._hasFocus = false;\n            this.blur.emit(this.createDynamicFormControlEvent($event, DynamicFormControlEventType.Blur));\n        }\n    }\n\n    onFocus($event: FocusEvent | DynamicFormControlEvent | any): void {\n        if (isDynamicFormControlEvent($event)) { // event bypass\n            this.focus.emit($event);\n\n        } else { // native HTML 5 or UI library focus event\n            this._hasFocus = true;\n            this.focus.emit(this.createDynamicFormControlEvent($event, DynamicFormControlEventType.Focus));\n        }\n    }\n\n    onCustomEvent($event: DynamicFormControlEvent | DynamicFormControlCustomEvent): void {\n        const emitter = this.customEvent as EventEmitter<DynamicFormControlEvent>;\n\n        if (isDynamicFormControlEvent($event)) { // child event bypass\n            emitter.emit($event);\n\n        } else { // native UI library custom event\n            emitter.emit(this.createDynamicFormControlEvent($event.customEvent, $event.customEventType));\n        }\n    }\n\n    private registerFormControlComponentRef(ref: ComponentRef<DynamicFormControl>): void {\n        if (this.context instanceof DynamicFormArrayGroupModel) {\n            this.componentService.registerFormControl(this.model, ref, this.context.index);\n\n        } else {\n            this.componentService.registerFormControl(this.model, ref);\n        }\n    }\n\n    private unregisterFormControlComponentRef(): void {\n        if (this.context instanceof DynamicFormArrayGroupModel) {\n            this.componentService.unregisterFormControl(this.model.id, this.context.index);\n\n        } else {\n            this.componentService.unregisterFormControl(this.model.id);\n        }\n    }\n}\n"]}