UNPKG

@formql/core

Version:

FormQL - A framework for building dynamic forms

110 lines 16 kB
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":";AAAA,OAAO,EAAE,SAAS,EAAU,KAAK,EAAE,gBAAgB,EAC/C,SAAS,EAAa,uBAAuB,EAAE,MAAM,eAAe,CAAC;AAEzE,OAAO,EAAE,2BAA2B,EAAE,MAAM,4CAA4C,CAAC;AACzF,OAAO,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AAEnE,OAAO,EAAE,wBAAwB,EAAE,MAAM,wCAAwC,CAAC;AAClF,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAyBjE,IAAa,2BAA2B,GAAxC,MAAa,2BAA2B;IAsBpC,YACY,wBAAkD,EAClD,gBAAkC,EAClC,mBAAgD,EAChD,YAA0B;QAH1B,6BAAwB,GAAxB,wBAAwB,CAA0B;QAClD,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,wBAAmB,GAAnB,mBAAmB,CAA6B;QAChD,iBAAY,GAAZ,YAAY,CAAc;QAT/B,eAAU,GAAG,UAAU,CAAC;QACxB,kBAAa,GAAG,aAAa,CAAC;IASlC,CAAC;IAjBJ,IAAI,KAAK,CAAC,KAAU;QAChB,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,KAAK,KAAK,KAAK;YACnH,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAClF,CAAC;IAgBD,QAAQ;QACJ,MAAM,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,IAAI,CAAC,wBAAwB,CAAC,gBAAgB,CAClG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC,CAAC;QAC7B,SAAU,CAAC,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC;QAC3C,SAAU,CAAC,QAAQ,CAAC,WAAW,GAAG,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;QAElG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QAExC,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YACjH,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,KAAK,MAAM,EAAE;gBACjC,IAAI,CAAC,SAAS,CAAC,KAAK,GAAG,MAAM,CAAC;gBAC9B,IAAI,CAAC,YAAY,CAAC,eAAe,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aACrD;QACL,CAAC,CAAC,CAAC;QAEH,IAAI,IAAI,CAAC,IAAI,KAAK,UAAU,CAAC,IAAI,EAAE;YAC/B,MAAM,OAAO,GAAG,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,IAAI,CAAC,wBAAwB,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,CAAC,CAAC;YACpH,OAAQ,CAAC,QAAQ,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;YACzC,OAAQ,CAAC,QAAQ,CAAC,IAAI,GAAG,aAAa,CAAC,SAAS,CAAC;YACjD,OAAQ,CAAC,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC;YAChD,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;SACzC;IACL,CAAC;IAED,SAAS;QACL,IAAI,IAAI,CAAC,IAAI,KAAK,UAAU,CAAC,IAAI;YAC7B,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;IAC1F,CAAC;IAED,WAAW;QACP,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE,CAAC;IACzC,CAAC;CACJ,CAAA;AA3DoE;IAAhE,SAAS,CAAC,SAAS,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,EAAG,IAAI,EAAE,CAAC;8BAAU,gBAAgB;4DAAC;AAC1B;IAAhE,SAAS,CAAC,SAAS,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,EAAG,IAAI,EAAE,CAAC;8BAAU,gBAAgB;4DAAC;AAC1B;IAAhE,SAAS,CAAC,SAAS,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,EAAG,IAAI,EAAE,CAAC;8BAAU,gBAAgB;4DAAC;AAElF;IAAR,KAAK,EAAE;;8DAA+B;AAC9B;IAAR,KAAK,EAAE;8BAAkB,SAAS;oEAAC;AAC3B;IAAR,KAAK,EAAE;;8DAAmB;AAE3B;IADC,KAAK,EAAE;;;wDAIP;AAEQ;IAAR,KAAK,EAAE;;yDAAkB;AAfjB,2BAA2B;IAtBvC,SAAS,CAAC;QACP,+CAA+C;QAC/C,QAAQ,EAAE,8BAA8B;QACxC,QAAQ,EAAE;;;;;;;;;;;;;;WAcH;QAEP,eAAe,EAAE,uBAAuB,CAAC,MAAM;;KAElD,CAAC;qCAwBwC,wBAAwB;QAChC,gBAAgB;QACb,2BAA2B;QAClC,YAAY;GA1B7B,2BAA2B,CA6DvC;SA7DY,2BAA2B","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"]}