import { __decorate, __metadata, __param } from "tslib"; import { AfterViewInit, Component, ComponentFactoryResolver, Directive, ElementRef, HostBinding, HostListener, Inject, Input, OnChanges, OnInit, SimpleChanges, ViewChild, ViewContainerRef } from '@angular/core'; import { FC_NODE_COMPONENT_CONFIG, FlowchartConstants } from './ngx-flowchart.models'; import { FcModelService } from './model.service'; let FcNodeContainerComponent = class FcNodeContainerComponent { constructor(nodeComponentConfig, elementRef, componentFactoryResolver) { this.nodeComponentConfig = nodeComponentConfig; this.elementRef = elementRef; this.componentFactoryResolver = componentFactoryResolver; } get nodeId() { return this.node.id; } get top() { return this.node.y + 'px'; } get left() { return this.node.x + 'px'; } ngOnInit() { if (!this.userNodeCallbacks) { this.userNodeCallbacks = {}; } this.userNodeCallbacks.nodeEdit = this.userNodeCallbacks.nodeEdit || (() => { }); this.userNodeCallbacks.doubleClick = this.userNodeCallbacks.doubleClick || (() => { }); this.userNodeCallbacks.mouseDown = this.userNodeCallbacks.mouseDown || (() => { }); this.userNodeCallbacks.mouseEnter = this.userNodeCallbacks.mouseEnter || (() => { }); this.userNodeCallbacks.mouseLeave = this.userNodeCallbacks.mouseLeave || (() => { }); const element = $(this.elementRef.nativeElement); element.addClass(FlowchartConstants.nodeClass); if (!this.node.readonly) { element.attr('draggable', 'true'); } this.updateNodeClass(); this.modelservice.nodes.setHtmlElement(this.node.id, element[0]); this.nodeContentContainer.clear(); const componentFactory = this.componentFactoryResolver.resolveComponentFactory(this.nodeComponentConfig.nodeComponentType); const componentRef = this.nodeContentContainer.createComponent(componentFactory); this.nodeComponent = componentRef.instance; this.nodeComponent.callbacks = this.callbacks; this.nodeComponent.userNodeCallbacks = this.userNodeCallbacks; this.nodeComponent.node = this.node; this.nodeComponent.modelservice = this.modelservice; this.updateNodeComponent(); this.nodeComponent.width = this.elementRef.nativeElement.offsetWidth; this.nodeComponent.height = this.elementRef.nativeElement.offsetHeight; } ngAfterViewInit() { this.nodeComponent.width = this.elementRef.nativeElement.offsetWidth; this.nodeComponent.height = this.elementRef.nativeElement.offsetHeight; } ngOnChanges(changes) { let updateNode = false; for (const propName of Object.keys(changes)) { const change = changes[propName]; if (!change.firstChange && change.currentValue !== change.previousValue) { if (['selected', 'edit', 'underMouse', 'mouseOverConnector', 'dragging'].includes(propName)) { updateNode = true; } } } if (updateNode) { this.updateNodeClass(); this.updateNodeComponent(); } } updateNodeClass() { const element = $(this.elementRef.nativeElement); this.toggleClass(element, FlowchartConstants.selectedClass, this.selected); this.toggleClass(element, FlowchartConstants.editClass, this.edit); this.toggleClass(element, FlowchartConstants.hoverClass, this.underMouse); this.toggleClass(element, FlowchartConstants.draggingClass, this.dragging); } updateNodeComponent() { this.nodeComponent.selected = this.selected; this.nodeComponent.edit = this.edit; this.nodeComponent.underMouse = this.underMouse; this.nodeComponent.mouseOverConnector = this.mouseOverConnector; this.nodeComponent.dragging = this.dragging; } toggleClass(element, clazz, set) { if (set) { element.addClass(clazz); } else { element.removeClass(clazz); } } mousedown(event) { event.stopPropagation(); } dragstart(event) { if (!this.node.readonly) { this.callbacks.nodeDragstart(event, this.node); } } dragend(event) { if (!this.node.readonly) { this.callbacks.nodeDragend(event); } } click(event) { if (!this.node.readonly) { this.callbacks.nodeClicked(event, this.node); } } mouseover(event) { if (!this.node.readonly) { this.callbacks.nodeMouseOver(event, this.node); } } mouseout(event) { if (!this.node.readonly) { this.callbacks.nodeMouseOut(event, this.node); } } }; FcNodeContainerComponent.ctorParameters = () => [ { type: undefined, decorators: [{ type: Inject, args: [FC_NODE_COMPONENT_CONFIG,] }] }, { type: ElementRef }, { type: ComponentFactoryResolver } ]; __decorate([ Input(), __metadata("design:type", Object) ], FcNodeContainerComponent.prototype, "callbacks", void 0); __decorate([ Input(), __metadata("design:type", Object) ], FcNodeContainerComponent.prototype, "userNodeCallbacks", void 0); __decorate([ Input(), __metadata("design:type", Object) ], FcNodeContainerComponent.prototype, "node", void 0); __decorate([ Input(), __metadata("design:type", Boolean) ], FcNodeContainerComponent.prototype, "selected", void 0); __decorate([ Input(), __metadata("design:type", Boolean) ], FcNodeContainerComponent.prototype, "edit", void 0); __decorate([ Input(), __metadata("design:type", Boolean) ], FcNodeContainerComponent.prototype, "underMouse", void 0); __decorate([ Input(), __metadata("design:type", Object) ], FcNodeContainerComponent.prototype, "mouseOverConnector", void 0); __decorate([ Input(), __metadata("design:type", FcModelService) ], FcNodeContainerComponent.prototype, "modelservice", void 0); __decorate([ Input(), __metadata("design:type", Boolean) ], FcNodeContainerComponent.prototype, "dragging", void 0); __decorate([ HostBinding('attr.id'), __metadata("design:type", String), __metadata("design:paramtypes", []) ], FcNodeContainerComponent.prototype, "nodeId", null); __decorate([ HostBinding('style.top'), __metadata("design:type", String), __metadata("design:paramtypes", []) ], FcNodeContainerComponent.prototype, "top", null); __decorate([ HostBinding('style.left'), __metadata("design:type", String), __metadata("design:paramtypes", []) ], FcNodeContainerComponent.prototype, "left", null); __decorate([ ViewChild('nodeContent', { read: ViewContainerRef, static: true }), __metadata("design:type", ViewContainerRef) ], FcNodeContainerComponent.prototype, "nodeContentContainer", void 0); __decorate([ HostListener('mousedown', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [MouseEvent]), __metadata("design:returntype", void 0) ], FcNodeContainerComponent.prototype, "mousedown", null); __decorate([ HostListener('dragstart', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [DragEvent]), __metadata("design:returntype", void 0) ], FcNodeContainerComponent.prototype, "dragstart", null); __decorate([ HostListener('dragend', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [DragEvent]), __metadata("design:returntype", void 0) ], FcNodeContainerComponent.prototype, "dragend", null); __decorate([ HostListener('click', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [MouseEvent]), __metadata("design:returntype", void 0) ], FcNodeContainerComponent.prototype, "click", null); __decorate([ HostListener('mouseover', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [MouseEvent]), __metadata("design:returntype", void 0) ], FcNodeContainerComponent.prototype, "mouseover", null); __decorate([ HostListener('mouseout', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [MouseEvent]), __metadata("design:returntype", void 0) ], FcNodeContainerComponent.prototype, "mouseout", null); FcNodeContainerComponent = __decorate([ Component({ selector: 'fc-node', template: '', styles: [":host{position:absolute;z-index:1}:host.fc-dragging{z-index:10}:host ::ng-deep .fc-leftConnectors,:host ::ng-deep .fc-rightConnectors{position:absolute;top:0;height:100%;display:-webkit-box;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;flex-direction:column;z-index:-10}:host ::ng-deep .fc-leftConnectors .fc-magnet,:host ::ng-deep .fc-rightConnectors .fc-magnet{-webkit-box-align:center;align-items:center}:host ::ng-deep .fc-leftConnectors{left:-20px}:host ::ng-deep .fc-rightConnectors{right:-20px}:host ::ng-deep .fc-magnet{display:-webkit-box;display:flex;-webkit-box-flex:1;flex-grow:1;height:60px;-webkit-box-pack:center;justify-content:center}:host ::ng-deep .fc-connector{width:18px;height:18px;border:10px solid transparent;-moz-background-clip:padding;-webkit-background-clip:padding;background-clip:padding-box;border-radius:50%;background-color:#f7a789;color:#fff;pointer-events:all}:host ::ng-deep .fc-connector.fc-hover{background-color:#000}"] }), __param(0, Inject(FC_NODE_COMPONENT_CONFIG)), __metadata("design:paramtypes", [Object, ElementRef, ComponentFactoryResolver]) ], FcNodeContainerComponent); export { FcNodeContainerComponent }; let FcNodeComponent = class FcNodeComponent { constructor() { this.flowchartConstants = FlowchartConstants; this.nodeRectInfo = { top: () => { return this.node.y; }, left: () => { return this.node.x; }, bottom: () => { return this.node.y + this.height; }, right: () => { return this.node.x + this.width; }, width: () => { return this.width; }, height: () => { return this.height; } }; } ngOnInit() { } }; __decorate([ Input(), __metadata("design:type", Object) ], FcNodeComponent.prototype, "callbacks", void 0); __decorate([ Input(), __metadata("design:type", Object) ], FcNodeComponent.prototype, "userNodeCallbacks", void 0); __decorate([ Input(), __metadata("design:type", Object) ], FcNodeComponent.prototype, "node", void 0); __decorate([ Input(), __metadata("design:type", Boolean) ], FcNodeComponent.prototype, "selected", void 0); __decorate([ Input(), __metadata("design:type", Boolean) ], FcNodeComponent.prototype, "edit", void 0); __decorate([ Input(), __metadata("design:type", Boolean) ], FcNodeComponent.prototype, "underMouse", void 0); __decorate([ Input(), __metadata("design:type", Object) ], FcNodeComponent.prototype, "mouseOverConnector", void 0); __decorate([ Input(), __metadata("design:type", FcModelService) ], FcNodeComponent.prototype, "modelservice", void 0); __decorate([ Input(), __metadata("design:type", Boolean) ], FcNodeComponent.prototype, "dragging", void 0); FcNodeComponent = __decorate([ Directive() ], FcNodeComponent); export { FcNodeComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node.component.js","sourceRoot":"ng://ngx-flowchart/","sources":["lib/node.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ComponentFactoryResolver, Directive,\n  ElementRef, HostBinding,\n  HostListener,\n  Inject,\n  Input,\n  OnChanges,\n  OnInit,\n  SimpleChanges,\n  ViewChild,\n  ViewContainerRef\n} from '@angular/core';\nimport {\n  FC_NODE_COMPONENT_CONFIG,\n  FcCallbacks,\n  FcConnector,\n  FcNode,\n  FcNodeComponentConfig, FcNodeRectInfo,\n  FlowchartConstants,\n  UserNodeCallbacks\n} from './ngx-flowchart.models';\nimport { FcModelService } from './model.service';\n\n@Component({\n  selector: 'fc-node',\n  template: '<ng-template #nodeContent></ng-template>',\n  styleUrls: ['./node.component.scss']\n})\nexport class FcNodeContainerComponent implements OnInit, AfterViewInit, OnChanges {\n\n  @Input()\n  callbacks: FcCallbacks;\n\n  @Input()\n  userNodeCallbacks: UserNodeCallbacks;\n\n  @Input()\n  node: FcNode;\n\n  @Input()\n  selected: boolean;\n\n  @Input()\n  edit: boolean;\n\n  @Input()\n  underMouse: boolean;\n\n  @Input()\n  mouseOverConnector: FcConnector;\n\n  @Input()\n  modelservice: FcModelService;\n\n  @Input()\n  dragging: boolean;\n\n  @HostBinding('attr.id')\n  get nodeId(): string {\n    return this.node.id;\n  }\n\n  @HostBinding('style.top')\n  get top(): string {\n    return this.node.y + 'px';\n  }\n\n  @HostBinding('style.left')\n  get left(): string {\n    return this.node.x + 'px';\n  }\n\n  nodeComponent: FcNodeComponent;\n\n  @ViewChild('nodeContent', {read: ViewContainerRef, static: true}) nodeContentContainer: ViewContainerRef;\n\n  constructor(@Inject(FC_NODE_COMPONENT_CONFIG) private nodeComponentConfig: FcNodeComponentConfig,\n              private elementRef: ElementRef<HTMLElement>,\n              private componentFactoryResolver: ComponentFactoryResolver) {\n  }\n\n  ngOnInit(): void {\n    if (!this.userNodeCallbacks) {\n      this.userNodeCallbacks = {};\n    }\n    this.userNodeCallbacks.nodeEdit = this.userNodeCallbacks.nodeEdit || (() => {});\n    this.userNodeCallbacks.doubleClick = this.userNodeCallbacks.doubleClick || (() => {});\n    this.userNodeCallbacks.mouseDown = this.userNodeCallbacks.mouseDown || (() => {});\n    this.userNodeCallbacks.mouseEnter = this.userNodeCallbacks.mouseEnter || (() => {});\n    this.userNodeCallbacks.mouseLeave = this.userNodeCallbacks.mouseLeave || (() => {});\n\n    const element = $(this.elementRef.nativeElement);\n    element.addClass(FlowchartConstants.nodeClass);\n    if (!this.node.readonly) {\n      element.attr('draggable', 'true');\n    }\n    this.updateNodeClass();\n    this.modelservice.nodes.setHtmlElement(this.node.id, element[0]);\n    this.nodeContentContainer.clear();\n    const componentFactory = this.componentFactoryResolver.resolveComponentFactory(this.nodeComponentConfig.nodeComponentType);\n    const componentRef = this.nodeContentContainer.createComponent(componentFactory);\n    this.nodeComponent = componentRef.instance;\n    this.nodeComponent.callbacks = this.callbacks;\n    this.nodeComponent.userNodeCallbacks = this.userNodeCallbacks;\n    this.nodeComponent.node = this.node;\n    this.nodeComponent.modelservice = this.modelservice;\n    this.updateNodeComponent();\n    this.nodeComponent.width = this.elementRef.nativeElement.offsetWidth;\n    this.nodeComponent.height = this.elementRef.nativeElement.offsetHeight;\n  }\n\n  ngAfterViewInit(): void {\n    this.nodeComponent.width = this.elementRef.nativeElement.offsetWidth;\n    this.nodeComponent.height = this.elementRef.nativeElement.offsetHeight;\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    let updateNode = false;\n    for (const propName of Object.keys(changes)) {\n      const change = changes[propName];\n      if (!change.firstChange && change.currentValue !== change.previousValue) {\n        if (['selected', 'edit', 'underMouse', 'mouseOverConnector', 'dragging'].includes(propName)) {\n          updateNode = true;\n        }\n      }\n    }\n    if (updateNode) {\n      this.updateNodeClass();\n      this.updateNodeComponent();\n    }\n  }\n\n  private updateNodeClass() {\n    const element = $(this.elementRef.nativeElement);\n    this.toggleClass(element, FlowchartConstants.selectedClass, this.selected);\n    this.toggleClass(element, FlowchartConstants.editClass, this.edit);\n    this.toggleClass(element, FlowchartConstants.hoverClass, this.underMouse);\n    this.toggleClass(element, FlowchartConstants.draggingClass, this.dragging);\n  }\n\n  private updateNodeComponent() {\n    this.nodeComponent.selected = this.selected;\n    this.nodeComponent.edit = this.edit;\n    this.nodeComponent.underMouse = this.underMouse;\n    this.nodeComponent.mouseOverConnector = this.mouseOverConnector;\n    this.nodeComponent.dragging = this.dragging;\n  }\n\n  private toggleClass(element: JQuery<HTMLElement>, clazz: string, set: boolean) {\n    if (set) {\n      element.addClass(clazz);\n    } else {\n      element.removeClass(clazz);\n    }\n  }\n\n  @HostListener('mousedown', ['$event'])\n  mousedown(event: MouseEvent) {\n    event.stopPropagation();\n  }\n\n  @HostListener('dragstart', ['$event'])\n  dragstart(event: DragEvent) {\n    if (!this.node.readonly) {\n      this.callbacks.nodeDragstart(event, this.node);\n    }\n  }\n\n  @HostListener('dragend', ['$event'])\n  dragend(event: DragEvent) {\n    if (!this.node.readonly) {\n      this.callbacks.nodeDragend(event);\n    }\n  }\n\n  @HostListener('click', ['$event'])\n  click(event: MouseEvent) {\n    if (!this.node.readonly) {\n      this.callbacks.nodeClicked(event, this.node);\n    }\n  }\n\n  @HostListener('mouseover', ['$event'])\n  mouseover(event: MouseEvent) {\n    if (!this.node.readonly) {\n      this.callbacks.nodeMouseOver(event, this.node);\n    }\n  }\n\n  @HostListener('mouseout', ['$event'])\n  mouseout(event: MouseEvent) {\n    if (!this.node.readonly) {\n      this.callbacks.nodeMouseOut(event, this.node);\n    }\n  }\n\n}\n\n@Directive()\nexport abstract class FcNodeComponent implements OnInit {\n\n  @Input()\n  callbacks: FcCallbacks;\n\n  @Input()\n  userNodeCallbacks: UserNodeCallbacks;\n\n  @Input()\n  node: FcNode;\n\n  @Input()\n  selected: boolean;\n\n  @Input()\n  edit: boolean;\n\n  @Input()\n  underMouse: boolean;\n\n  @Input()\n  mouseOverConnector: FcConnector;\n\n  @Input()\n  modelservice: FcModelService;\n\n  @Input()\n  dragging: boolean;\n\n  flowchartConstants = FlowchartConstants;\n\n  width: number;\n\n  height: number;\n\n  nodeRectInfo: FcNodeRectInfo = {\n    top: () => {\n      return this.node.y;\n    },\n\n    left: () => {\n      return this.node.x;\n    },\n\n    bottom: () => {\n      return this.node.y + this.height;\n    },\n\n    right: () => {\n      return this.node.x + this.width;\n    },\n\n    width: () => {\n      return this.width;\n    },\n\n    height: () => {\n      return this.height;\n    }\n  };\n\n  ngOnInit(): void {\n  }\n\n}\n"]}