ngx-xyflow
Version:
Angular wrapper for the popular xyflow (formerly Reactflow) library
218 lines • 24.5 kB
JavaScript
import { NgTemplateOutlet } from '@angular/common';
import { Component, ContentChild, ContentChildren, Directive, EventEmitter, Input, Output, TemplateRef } from '@angular/core';
import { Handle, NodeResizer, NodeToolbar } from '@xyflow/react';
import * as React from 'react';
import { HandleDirective } from './handle.directive';
import { NodeResizerDirective } from './node-resizer.directive';
import { NodeToolbarDirective } from './node-toolbar.directive';
import { AutoWrapAngularObject, ng2ReactProps } from 'ngx-reactify';
import * as i0 from "@angular/core";
import * as i1 from "./xyflow.component";
class XYFlowNodeComponent {
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: XYFlowNodeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: XYFlowNodeComponent, isStandalone: true, selector: "ngx-xyflow-node", inputs: { template: "template", data: "data", node: "node" }, ngImport: i0, template: `
@if(template) {
<ng-container
[ngTemplateOutlet]="template"
[ngTemplateOutletContext]="{ '$implicit': data }"
/>
}
@else {
<span style="color: red">
Node has no template.
</span>
}
`, isInline: true, dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: XYFlowNodeComponent, decorators: [{
type: Component,
args: [{
selector: "ngx-xyflow-node",
template: `
@if(template) {
<ng-container
[ngTemplateOutlet]="template"
[ngTemplateOutletContext]="{ '$implicit': data }"
/>
}
@else {
<span style="color: red">
Node has no template.
</span>
}
`,
imports: [
NgTemplateOutlet
],
standalone: true
}]
}], propDecorators: { template: [{
type: Input
}], data: [{
type: Input
}], node: [{
type: Input
}] } });
export class NodeDirective {
constructor(xyflow, appRef, injector, ngZone) {
this.xyflow = xyflow;
this.appRef = appRef;
this.injector = injector;
this.ngZone = ngZone;
this.blur = new EventEmitter();
this.click = new EventEmitter();
this.contextmenu = new EventEmitter();
this.dblclick = new EventEmitter();
this.drag = new EventEmitter();
this.dragend = new EventEmitter();
this.dragenter = new EventEmitter();
this.dragleave = new EventEmitter();
this.dragover = new EventEmitter();
this.dragstart = new EventEmitter();
this.focus = new EventEmitter();
this.keydown = new EventEmitter();
this.keyup = new EventEmitter();
this.keypress = new EventEmitter();
this.mousedown = new EventEmitter();
this.mouseenter = new EventEmitter();
this.mouseleave = new EventEmitter();
this.mousemove = new EventEmitter();
this.mouseout = new EventEmitter();
this.mouseover = new EventEmitter();
this.mouseup = new EventEmitter();
this.mousewheel = new EventEmitter();
this.pointercancel = new EventEmitter();
this.pointerdown = new EventEmitter();
this.pointerenter = new EventEmitter();
this.pointerleave = new EventEmitter();
this.pointermove = new EventEmitter();
this.pointerout = new EventEmitter();
this.pointerover = new EventEmitter();
this.pointerrawupdate = new EventEmitter();
this.pointerup = new EventEmitter();
this.resize = new EventEmitter();
this.scroll = new EventEmitter();
this.wheel = new EventEmitter();
}
ngOnChanges(changes) {
this.xyflow.ngOnChanges(changes);
}
ngAfterViewInit() {
if (!this.nodeType) {
console.error(new Error("NGX: XYFlow Node bootstrapped without a node type!\n"));
return;
}
this.xyflow.nodeTypes[this.nodeType] = AutoWrapAngularObject({
component: XYFlowNodeComponent,
appRef: this.appRef,
injector: this.injector,
instance: this,
ngZone: this.ngZone,
containerTag: "ngx-xyflow-node-container",
reactTemplate: el => {
return React.createElement(React.Fragment, {}, ...[
this.nodeResizer ? React.createElement(NodeResizer, ng2ReactProps(this.nodeResizer)) : null,
this.nodeToolbar ? React.createElement(NodeToolbar, ng2ReactProps(this.nodeToolbar)) : null,
el,
...(this.handles?.map(handle => {
const props = ng2ReactProps(handle);
// props.onConnect = (connection) =>
// handle.onConnect.next(connection);
return React.createElement(Handle, props);
}) || []),
].filter(n => !!n));
}
});
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NodeDirective, deps: [{ token: i1.XYFlowComponent }, { token: i0.ApplicationRef }, { token: i0.Injector }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive }); }
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: NodeDirective, selector: "ngx-xyflow>ngx-xyflow-node", inputs: { nodeType: "nodeType" }, outputs: { blur: "blur", click: "click", contextmenu: "contextmenu", dblclick: "dblclick", drag: "drag", dragend: "dragend", dragenter: "dragenter", dragleave: "dragleave", dragover: "dragover", dragstart: "dragstart", focus: "focus", keydown: "keydown", keyup: "keyup", keypress: "keypress", mousedown: "mousedown", mouseenter: "mouseenter", mouseleave: "mouseleave", mousemove: "mousemove", mouseout: "mouseout", mouseover: "mouseover", mouseup: "mouseup", mousewheel: "mousewheel", pointercancel: "pointercancel", pointerdown: "pointerdown", pointerenter: "pointerenter", pointerleave: "pointerleave", pointermove: "pointermove", pointerout: "pointerout", pointerover: "pointerover", pointerrawupdate: "pointerrawupdate", pointerup: "pointerup", resize: "resize", scroll: "scroll", wheel: "wheel" }, queries: [{ propertyName: "template", first: true, predicate: TemplateRef, descendants: true }, { propertyName: "nodeResizer", first: true, predicate: NodeResizerDirective, descendants: true }, { propertyName: "nodeToolbar", first: true, predicate: NodeToolbarDirective, descendants: true }, { propertyName: "handles", predicate: HandleDirective }], usesOnChanges: true, ngImport: i0 }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NodeDirective, decorators: [{
type: Directive,
args: [{
selector: 'ngx-xyflow>ngx-xyflow-node'
}]
}], ctorParameters: () => [{ type: i1.XYFlowComponent }, { type: i0.ApplicationRef }, { type: i0.Injector }, { type: i0.NgZone }], propDecorators: { handles: [{
type: ContentChildren,
args: [HandleDirective]
}], nodeType: [{
type: Input
}], template: [{
type: ContentChild,
args: [TemplateRef]
}], nodeResizer: [{
type: ContentChild,
args: [NodeResizerDirective]
}], nodeToolbar: [{
type: ContentChild,
args: [NodeToolbarDirective]
}], blur: [{
type: Output
}], click: [{
type: Output
}], contextmenu: [{
type: Output
}], dblclick: [{
type: Output
}], drag: [{
type: Output
}], dragend: [{
type: Output
}], dragenter: [{
type: Output
}], dragleave: [{
type: Output
}], dragover: [{
type: Output
}], dragstart: [{
type: Output
}], focus: [{
type: Output
}], keydown: [{
type: Output
}], keyup: [{
type: Output
}], keypress: [{
type: Output
}], mousedown: [{
type: Output
}], mouseenter: [{
type: Output
}], mouseleave: [{
type: Output
}], mousemove: [{
type: Output
}], mouseout: [{
type: Output
}], mouseover: [{
type: Output
}], mouseup: [{
type: Output
}], mousewheel: [{
type: Output
}], pointercancel: [{
type: Output
}], pointerdown: [{
type: Output
}], pointerenter: [{
type: Output
}], pointerleave: [{
type: Output
}], pointermove: [{
type: Output
}], pointerout: [{
type: Output
}], pointerover: [{
type: Output
}], pointerrawupdate: [{
type: Output
}], pointerup: [{
type: Output
}], resize: [{
type: Output
}], scroll: [{
type: Output
}], wheel: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node.directive.js","sourceRoot":"","sources":["../../../src/xyflow/node.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EAEH,SAAS,EACT,YAAY,EACZ,eAAe,EACf,SAAS,EAET,YAAY,EAEZ,KAAK,EAEL,MAAM,EAGN,WAAW,EAEd,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AACjE,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAErD,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAChE,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAChE,OAAO,EAAE,qBAAqB,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;;;AAGpE,MAoBM,mBAAmB;+GAAnB,mBAAmB;mGAAnB,mBAAmB,yIAlBX;;;;;;;;;;;;KAYT,4DAEG,gBAAgB;;4FAIlB,mBAAmB;kBApBxB,SAAS;mBAAC;oBACP,QAAQ,EAAE,iBAAiB;oBAC3B,QAAQ,EAAE;;;;;;;;;;;;KAYT;oBACD,OAAO,EAAE;wBACL,gBAAgB;qBACnB;oBACD,UAAU,EAAE,IAAI;iBACnB;8BAEY,QAAQ;sBAAhB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,IAAI;sBAAZ,KAAK;;AAOV,MAAM,OAAO,aAAa;IA6CtB,YACqB,MAAuB,EACvB,MAAsB,EACtB,QAAkB,EAClB,MAAc;QAHd,WAAM,GAAN,MAAM,CAAiB;QACvB,WAAM,GAAN,MAAM,CAAgB;QACtB,aAAQ,GAAR,QAAQ,CAAU;QAClB,WAAM,GAAN,MAAM,CAAQ;QAvCzB,SAAI,GAAG,IAAI,YAAY,EAA+B,CAAC;QACvD,UAAK,GAAG,IAAI,YAAY,EAAgC,CAAC;QACzD,gBAAW,GAAG,IAAI,YAAY,EAAsC,CAAC;QACrE,aAAQ,GAAG,IAAI,YAAY,EAAmC,CAAC;QAC/D,SAAI,GAAG,IAAI,YAAY,EAA+B,CAAC;QACvD,YAAO,GAAG,IAAI,YAAY,EAAkC,CAAC;QAC7D,cAAS,GAAG,IAAI,YAAY,EAAoC,CAAC;QACjE,cAAS,GAAG,IAAI,YAAY,EAAoC,CAAC;QACjE,aAAQ,GAAG,IAAI,YAAY,EAAmC,CAAC;QAC/D,cAAS,GAAG,IAAI,YAAY,EAAoC,CAAC;QACjE,UAAK,GAAG,IAAI,YAAY,EAAgC,CAAC;QACzD,YAAO,GAAG,IAAI,YAAY,EAAkC,CAAC;QAC7D,UAAK,GAAG,IAAI,YAAY,EAAgC,CAAC;QACzD,aAAQ,GAAG,IAAI,YAAY,EAAmC,CAAC;QAC/D,cAAS,GAAG,IAAI,YAAY,EAAoC,CAAC;QACjE,eAAU,GAAG,IAAI,YAAY,EAAqC,CAAC;QACnE,eAAU,GAAG,IAAI,YAAY,EAAqC,CAAC;QACnE,cAAS,GAAG,IAAI,YAAY,EAAoC,CAAC;QACjE,aAAQ,GAAG,IAAI,YAAY,EAAmC,CAAC;QAC/D,cAAS,GAAG,IAAI,YAAY,EAAoC,CAAC;QACjE,YAAO,GAAG,IAAI,YAAY,EAAkC,CAAC;QAC7D,eAAU,GAAG,IAAI,YAAY,EAAgC,CAAC;QAC9D,kBAAa,GAAG,IAAI,YAAY,EAAwC,CAAC;QACzE,gBAAW,GAAG,IAAI,YAAY,EAAsC,CAAC;QACrE,iBAAY,GAAG,IAAI,YAAY,EAAuC,CAAC;QACvE,iBAAY,GAAG,IAAI,YAAY,EAAuC,CAAC;QACvE,gBAAW,GAAG,IAAI,YAAY,EAAsC,CAAC;QACrE,eAAU,GAAG,IAAI,YAAY,EAAqC,CAAC;QACnE,gBAAW,GAAG,IAAI,YAAY,EAAsC,CAAC;QACrE,qBAAgB,GAAG,IAAI,YAAY,EAAS,CAAC;QAC7C,cAAS,GAAG,IAAI,YAAY,EAAoC,CAAC;QACjE,WAAM,GAAG,IAAI,YAAY,EAAiC,CAAC;QAC3D,WAAM,GAAG,IAAI,YAAY,EAAiC,CAAC;QAC3D,UAAK,GAAG,IAAI,YAAY,EAAgC,CAAC;IAO/D,CAAC;IAEL,WAAW,CAAC,OAAsB;QAC9B,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;IACrC,CAAC;IAED,eAAe;QACX,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACjB,OAAO,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,sDAAsD,CAAC,CAAC,CAAC;YACjF,OAAO;QACX,CAAC;QAED,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,qBAAqB,CAAC;YACzD,SAAS,EAAE,mBAAmB;YAC9B,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,QAAQ,EAAE,IAAI;YACd,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,YAAY,EAAE,2BAA2B;YACzC,aAAa,EAAE,EAAE,CAAC,EAAE;gBAChB,OAAO,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC,QAAQ,EAAE,EAAE,EACzC,GAAG;oBACC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,KAAK,CAAC,aAAa,CAAC,WAAW,EAAE,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI;oBAC3F,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,KAAK,CAAC,aAAa,CAAC,WAAW,EAAE,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI;oBAC3F,EAAE;oBACF,GAAG,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,CAAC,MAAM,CAAC,EAAE;wBAC3B,MAAM,KAAK,GAAG,aAAa,CAAC,MAAM,CAAQ,CAAC;wBAC3C,oCAAoC;wBACpC,yCAAyC;wBAEzC,OAAO,KAAK,CAAC,aAAa,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;oBAC9C,CAAC,CAAC,IAAI,EAAE,CAAC;iBACZ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CACrB,CAAA;YACL,CAAC;SACJ,CAAC,CAAA;IACN,CAAC;+GAtFQ,aAAa;mGAAb,aAAa,66BAMR,WAAW,8EACX,oBAAoB,8EACpB,oBAAoB,6DANjB,eAAe;;4FAFvB,aAAa;kBAHzB,SAAS;mBAAC;oBACP,QAAQ,EAAE,4BAA4B;iBACzC;6JAGqC,OAAO;sBAAxC,eAAe;uBAAC,eAAe;gBAEvB,QAAQ;sBAAhB,KAAK;gBAEqB,QAAQ;sBAAlC,YAAY;uBAAC,WAAW;gBACW,WAAW;sBAA9C,YAAY;uBAAC,oBAAoB;gBACE,WAAW;sBAA9C,YAAY;uBAAC,oBAAoB;gBAExB,IAAI;sBAAb,MAAM;gBACG,KAAK;sBAAd,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACG,QAAQ;sBAAjB,MAAM;gBACG,IAAI;sBAAb,MAAM;gBACG,OAAO;sBAAhB,MAAM;gBACG,SAAS;sBAAlB,MAAM;gBACG,SAAS;sBAAlB,MAAM;gBACG,QAAQ;sBAAjB,MAAM;gBACG,SAAS;sBAAlB,MAAM;gBACG,KAAK;sBAAd,MAAM;gBACG,OAAO;sBAAhB,MAAM;gBACG,KAAK;sBAAd,MAAM;gBACG,QAAQ;sBAAjB,MAAM;gBACG,SAAS;sBAAlB,MAAM;gBACG,UAAU;sBAAnB,MAAM;gBACG,UAAU;sBAAnB,MAAM;gBACG,SAAS;sBAAlB,MAAM;gBACG,QAAQ;sBAAjB,MAAM;gBACG,SAAS;sBAAlB,MAAM;gBACG,OAAO;sBAAhB,MAAM;gBACG,UAAU;sBAAnB,MAAM;gBACG,aAAa;sBAAtB,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACG,YAAY;sBAArB,MAAM;gBACG,YAAY;sBAArB,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACG,UAAU;sBAAnB,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACG,gBAAgB;sBAAzB,MAAM;gBACG,SAAS;sBAAlB,MAAM;gBACG,MAAM;sBAAf,MAAM;gBACG,MAAM;sBAAf,MAAM;gBACG,KAAK;sBAAd,MAAM","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport {\n    ApplicationRef,\n    Component,\n    ContentChild,\n    ContentChildren,\n    Directive,\n    ElementRef,\n    EventEmitter,\n    Injector,\n    Input,\n    NgZone,\n    Output,\n    QueryList,\n    SimpleChanges,\n    TemplateRef,\n    ViewChildren\n} from '@angular/core';\nimport { Handle, NodeResizer, NodeToolbar } from '@xyflow/react';\nimport * as React from 'react';\nimport { HandleDirective } from './handle.directive';\nimport { XYFlowComponent } from './xyflow.component';\nimport { NodeResizerDirective } from './node-resizer.directive';\nimport { NodeToolbarDirective } from './node-toolbar.directive';\nimport { AutoWrapAngularObject, ng2ReactProps } from 'ngx-reactify';\n\n\n@Component({\n    selector: \"ngx-xyflow-node\",\n    template: `\n        @if(template) {\n            <ng-container\n                [ngTemplateOutlet]=\"template\"\n                [ngTemplateOutletContext]=\"{ '$implicit': data }\"\n            />\n        }\n        @else {\n            <span style=\"color: red\">\n                Node has no template.\n            </span>\n        }\n    `,\n    imports: [\n        NgTemplateOutlet\n    ],\n    standalone: true\n})\nclass XYFlowNodeComponent {\n    @Input() template: TemplateRef<any>;\n    @Input() data: any;\n    @Input() node: any;\n}\n\n\n@Directive({\n    selector: 'ngx-xyflow>ngx-xyflow-node'\n})\nexport class NodeDirective {\n\n    @ContentChildren(HandleDirective) handles: QueryList<HandleDirective>;\n\n    @Input() nodeType: string;\n\n    @ContentChild(TemplateRef) template: ElementRef;\n    @ContentChild(NodeResizerDirective) nodeResizer: NodeResizerDirective;\n    @ContentChild(NodeToolbarDirective) nodeToolbar: NodeToolbarDirective;\n\n    @Output() blur = new EventEmitter<HTMLElementEventMap['blur']>();\n    @Output() click = new EventEmitter<HTMLElementEventMap['click']>();\n    @Output() contextmenu = new EventEmitter<HTMLElementEventMap['contextmenu']>();\n    @Output() dblclick = new EventEmitter<HTMLElementEventMap['dblclick']>();\n    @Output() drag = new EventEmitter<HTMLElementEventMap['drag']>();\n    @Output() dragend = new EventEmitter<HTMLElementEventMap['dragend']>();\n    @Output() dragenter = new EventEmitter<HTMLElementEventMap['dragenter']>();\n    @Output() dragleave = new EventEmitter<HTMLElementEventMap['dragleave']>();\n    @Output() dragover = new EventEmitter<HTMLElementEventMap['dragover']>();\n    @Output() dragstart = new EventEmitter<HTMLElementEventMap['dragstart']>();\n    @Output() focus = new EventEmitter<HTMLElementEventMap['focus']>();\n    @Output() keydown = new EventEmitter<HTMLElementEventMap['keydown']>();\n    @Output() keyup = new EventEmitter<HTMLElementEventMap['keyup']>();\n    @Output() keypress = new EventEmitter<HTMLElementEventMap['keypress']>();\n    @Output() mousedown = new EventEmitter<HTMLElementEventMap['mousedown']>();\n    @Output() mouseenter = new EventEmitter<HTMLElementEventMap['mouseenter']>();\n    @Output() mouseleave = new EventEmitter<HTMLElementEventMap['mouseleave']>();\n    @Output() mousemove = new EventEmitter<HTMLElementEventMap['mousemove']>();\n    @Output() mouseout = new EventEmitter<HTMLElementEventMap['mouseout']>();\n    @Output() mouseover = new EventEmitter<HTMLElementEventMap['mouseover']>();\n    @Output() mouseup = new EventEmitter<HTMLElementEventMap['mouseup']>();\n    @Output() mousewheel = new EventEmitter<HTMLElementEventMap['wheel']>();\n    @Output() pointercancel = new EventEmitter<HTMLElementEventMap['pointercancel']>();\n    @Output() pointerdown = new EventEmitter<HTMLElementEventMap['pointerdown']>();\n    @Output() pointerenter = new EventEmitter<HTMLElementEventMap['pointerenter']>();\n    @Output() pointerleave = new EventEmitter<HTMLElementEventMap['pointerleave']>();\n    @Output() pointermove = new EventEmitter<HTMLElementEventMap['pointermove']>();\n    @Output() pointerout = new EventEmitter<HTMLElementEventMap['pointerout']>();\n    @Output() pointerover = new EventEmitter<HTMLElementEventMap['pointerover']>();\n    @Output() pointerrawupdate = new EventEmitter<Event>();\n    @Output() pointerup = new EventEmitter<HTMLElementEventMap['pointerup']>();\n    @Output() resize = new EventEmitter<HTMLElementEventMap['resize']>();\n    @Output() scroll = new EventEmitter<HTMLElementEventMap['scroll']>();\n    @Output() wheel = new EventEmitter<HTMLElementEventMap['wheel']>();\n\n    constructor(\n        private readonly xyflow: XYFlowComponent,\n        private readonly appRef: ApplicationRef,\n        private readonly injector: Injector,\n        private readonly ngZone: NgZone\n    ) { }\n\n    ngOnChanges(changes: SimpleChanges) {\n        this.xyflow.ngOnChanges(changes);\n    }\n\n    ngAfterViewInit() {\n        if (!this.nodeType) {\n            console.error(new Error(\"NGX: XYFlow Node bootstrapped without a node type!\\n\"));\n            return;\n        }\n\n        this.xyflow.nodeTypes[this.nodeType] = AutoWrapAngularObject({\n            component: XYFlowNodeComponent,\n            appRef: this.appRef,\n            injector: this.injector,\n            instance: this,\n            ngZone: this.ngZone,\n            containerTag: \"ngx-xyflow-node-container\",\n            reactTemplate: el => {\n                return React.createElement(React.Fragment, {},\n                    ...[\n                        this.nodeResizer ? React.createElement(NodeResizer, ng2ReactProps(this.nodeResizer)) : null,\n                        this.nodeToolbar ? React.createElement(NodeToolbar, ng2ReactProps(this.nodeToolbar)) : null,\n                        el,\n                        ...(this.handles?.map(handle => {\n                            const props = ng2ReactProps(handle) as any;\n                            // props.onConnect = (connection) =>\n                            //     handle.onConnect.next(connection);\n\n                            return React.createElement(Handle, props);\n                        }) || []),\n                    ].filter(n => !!n)\n                )\n            }\n        })\n    }\n}\n"]}