@formql/core
Version:
FormQL - A framework for building dynamic forms
110 lines • 16 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { Component, Input, ViewContainerRef, ViewChild, ChangeDetectionStrategy } from '@angular/core';
import { InternalEventHandlerService } from '../services/internal-event-handler.service';
import { InternalEventType } from '../models/internal-event.model';
import { ComponentResolverService } from '../services/component-resolver.service';
import { FormGroup } from '@angular/forms';
import { StoreService } from '../services/store.service';
import { FormQLMode, ContainerType } from '../models/type.model';
let ComponentContainerComponent = class ComponentContainerComponent {
constructor(componentResolverService, viewContainerRef, eventHandlerService, storeService) {
this.componentResolverService = componentResolverService;
this.viewContainerRef = viewContainerRef;
this.eventHandlerService = eventHandlerService;
this.storeService = storeService;
this.FormQLMode = FormQLMode;
this.ContainerType = ContainerType;
}
set value(value) {
if (this.reactiveSection && this.component && this.reactiveSection.controls[this.component.componentId].value !== value)
this.reactiveSection.controls[this.component.componentId].setValue(value);
}
ngOnInit() {
const component = this.viewContainerRef.createComponent(this.componentResolverService.resolveComponent(this.component.componentName));
component.instance.field = this.component;
component.instance.formControl = this.reactiveSection.controls[this.component.componentId];
this.content.insert(component.hostView);
this.formSubscription$ = this.reactiveSection.controls[this.component.componentId].valueChanges.subscribe((change) => {
if (this.component.value !== change) {
this.component.value = change;
this.storeService.updateComponent(this.component);
}
});
if (this.mode === FormQLMode.Edit) {
const tooltip = this.viewContainerRef.createComponent(this.componentResolverService.resolveComponent('TooltipComponent'));
tooltip.instance.wrapper = this.wrapper;
tooltip.instance.type = ContainerType.Component;
tooltip.instance.object = this.component;
this.tooltip.insert(tooltip.hostView);
}
}
editField() {
if (this.mode === FormQLMode.Edit)
this.eventHandlerService.send(InternalEventType.EditingComponent, this.component);
}
ngOnDestroy() {
this.formSubscription$.unsubscribe();
}
};
__decorate([
ViewChild('content', { read: ViewContainerRef, static: true }),
__metadata("design:type", ViewContainerRef)
], ComponentContainerComponent.prototype, "content", void 0);
__decorate([
ViewChild('wrapper', { read: ViewContainerRef, static: true }),
__metadata("design:type", ViewContainerRef)
], ComponentContainerComponent.prototype, "wrapper", void 0);
__decorate([
ViewChild('tooltip', { read: ViewContainerRef, static: true }),
__metadata("design:type", ViewContainerRef)
], ComponentContainerComponent.prototype, "tooltip", void 0);
__decorate([
Input(),
__metadata("design:type", Object)
], ComponentContainerComponent.prototype, "component", void 0);
__decorate([
Input(),
__metadata("design:type", FormGroup)
], ComponentContainerComponent.prototype, "reactiveSection", void 0);
__decorate([
Input(),
__metadata("design:type", String)
], ComponentContainerComponent.prototype, "sectionId", void 0);
__decorate([
Input(),
__metadata("design:type", Object),
__metadata("design:paramtypes", [Object])
], ComponentContainerComponent.prototype, "value", null);
__decorate([
Input(),
__metadata("design:type", Number)
], ComponentContainerComponent.prototype, "mode", void 0);
ComponentContainerComponent = __decorate([
Component({
// tslint:disable-next-line: component-selector
selector: '[formql-component-container]',
template: `
<div #wrapper formqlDnd
[sourceObjectId]="component.componentId"
[attr.componentId]="component.componentId"
[sourceWrapperId]="sectionId"
[type]="ContainerType.Component"
[mode]="mode"
[ngClass]="{'fql-component-container-wrapper': (mode === FormQLMode.Edit) }">
<div class="fql-component-tooltip">
<ng-container #tooltip></ng-container>
</div>
<div class="fql-component-container" [ngStyle]="component.style">
<ng-container #content></ng-container>
</div>
</div>`,
changeDetection: ChangeDetectionStrategy.OnPush,
styles: [".fql-bundle-field-input{width:100%;box-sizing:border-box;-webkit-box-sizing:border-box;-moz-box-sizing:border-box}.fql-bundle-checkbox-input{cursor:pointer;box-sizing:border-box;-webkit-box-sizing:border-box;-moz-box-sizing:border-box}.fql-bundle-label-required:after{content:\" *\";color:red}.fql-bundle-field-radio{cursor:pointer}.fql-error-message{text-align:center;padding:20px}.fql-dnd-container-separator{box-shadow:0 -2px 0 #00f}.fql-dnd-container-drop-area{outline:dashed 3px}.fql-component-container{padding:10px}.fql-component-container-wrapper{position:relative;border:1px solid transparent;transition:border .3s ease-in-out}.fql-component-container-wrapper:hover .fql-component-tooltip{opacity:1;transition:opacity .3s ease-in-out}.fql-component-container-wrapper:hover{border:1px solid;transition:box-shadow .3s ease-in-out,border .3s ease-in-out}.fql-component-tooltip{opacity:0;display:block;position:absolute;left:50%;z-index:1;transition:opacity .3s ease-in-out}"]
}),
__metadata("design:paramtypes", [ComponentResolverService,
ViewContainerRef,
InternalEventHandlerService,
StoreService])
], ComponentContainerComponent);
export { ComponentContainerComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component-container.component.js","sourceRoot":"ng://@formql/core/","sources":["components/component-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, ViewContainerRef,\r\n    ViewChild, OnDestroy, ChangeDetectionStrategy } from '@angular/core';\r\nimport { FormComponent } from '../models/form-component.model';\r\nimport { InternalEventHandlerService } from '../services/internal-event-handler.service';\r\nimport { InternalEventType } from '../models/internal-event.model';\r\nimport { HelperService } from '../services/helper.service';\r\nimport { ComponentResolverService } from '../services/component-resolver.service';\r\nimport { FormGroup } from '@angular/forms';\r\nimport { StoreService } from '../services/store.service';\r\nimport { FormQLMode, ContainerType } from '../models/type.model';\r\nimport { Subscription } from 'rxjs';\r\n\r\n@Component({\r\n    // tslint:disable-next-line: component-selector\r\n    selector: '[formql-component-container]',\r\n    template: `\r\n    <div #wrapper formqlDnd\r\n        [sourceObjectId]=\"component.componentId\"\r\n        [attr.componentId]=\"component.componentId\"\r\n        [sourceWrapperId]=\"sectionId\"\r\n        [type]=\"ContainerType.Component\"\r\n        [mode]=\"mode\"\r\n        [ngClass]=\"{'fql-component-container-wrapper': (mode === FormQLMode.Edit) }\">\r\n        <div class=\"fql-component-tooltip\">\r\n            <ng-container #tooltip></ng-container>\r\n        </div>\r\n        <div class=\"fql-component-container\" [ngStyle]=\"component.style\">\r\n            <ng-container #content></ng-container>\r\n        </div>\r\n    </div>`,\r\n    styleUrls: ['./component-container.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n\r\n})\r\nexport class ComponentContainerComponent implements OnInit, OnDestroy {\r\n\r\n    @ViewChild('content', { read: ViewContainerRef, static : true }) content: ViewContainerRef;\r\n    @ViewChild('wrapper', { read: ViewContainerRef, static : true }) wrapper: ViewContainerRef;\r\n    @ViewChild('tooltip', { read: ViewContainerRef, static : true }) tooltip: ViewContainerRef;\r\n\r\n    @Input() component: FormComponent<any>;\r\n    @Input() reactiveSection: FormGroup;\r\n    @Input() sectionId: string;\r\n    @Input()\r\n    set value(value: any) {\r\n        if (this.reactiveSection && this.component && this.reactiveSection.controls[this.component.componentId].value !== value)\r\n            this.reactiveSection.controls[this.component.componentId].setValue(value);\r\n    }\r\n\r\n    @Input() mode: FormQLMode;\r\n\r\n    public FormQLMode = FormQLMode;\r\n    public ContainerType = ContainerType;\r\n\r\n    formSubscription$: Subscription;\r\n\r\n    constructor(\r\n        private componentResolverService: ComponentResolverService,\r\n        private viewContainerRef: ViewContainerRef,\r\n        private eventHandlerService: InternalEventHandlerService,\r\n        private storeService: StoreService\r\n    ) {}\r\n\r\n    ngOnInit() {\r\n        const component = this.viewContainerRef.createComponent(this.componentResolverService.resolveComponent(\r\n            this.component.componentName));\r\n        (<any>component).instance.field = this.component;\r\n        (<any>component).instance.formControl = this.reactiveSection.controls[this.component.componentId];\r\n\r\n        this.content.insert(component.hostView);\r\n\r\n        this.formSubscription$ = this.reactiveSection.controls[this.component.componentId].valueChanges.subscribe((change) => {\r\n            if (this.component.value !== change) {\r\n                this.component.value = change;\r\n                this.storeService.updateComponent(this.component);\r\n            }\r\n        });\r\n\r\n        if (this.mode === FormQLMode.Edit) {\r\n            const tooltip = this.viewContainerRef.createComponent(this.componentResolverService.resolveComponent('TooltipComponent'));\r\n            (<any>tooltip).instance.wrapper = this.wrapper;\r\n            (<any>tooltip).instance.type = ContainerType.Component;\r\n            (<any>tooltip).instance.object = this.component;\r\n            this.tooltip.insert(tooltip.hostView);\r\n        }\r\n    }\r\n\r\n    editField() {\r\n        if (this.mode === FormQLMode.Edit)\r\n            this.eventHandlerService.send(InternalEventType.EditingComponent, this.component);\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this.formSubscription$.unsubscribe();\r\n    }\r\n}\r\n"]}