/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { Directive, ElementRef, HostListener, Input } from '@angular/core'; import { FlowchartConstants } from './ngx-flowchart.models'; import { FcModelService } from './model.service'; var FcConnectorDirective = /** @class */ (function () { function FcConnectorDirective(elementRef) { this.elementRef = elementRef; } /** * @return {?} */ FcConnectorDirective.prototype.ngOnInit = /** * @return {?} */ function () { /** @type {?} */ var element = $(this.elementRef.nativeElement); element.addClass(FlowchartConstants.connectorClass); if (this.modelservice.isEditable()) { element.attr('draggable', 'true'); this.updateConnectorClass(); } /** @type {?} */ var connectorRectInfo = { type: this.connector.type, width: this.elementRef.nativeElement.offsetWidth, height: this.elementRef.nativeElement.offsetHeight, nodeRectInfo: this.nodeRectInfo }; this.modelservice.connectors.setConnectorRectInfo(this.connector.id, connectorRectInfo); }; /** * @param {?} changes * @return {?} */ FcConnectorDirective.prototype.ngOnChanges = /** * @param {?} changes * @return {?} */ function (changes) { var e_1, _a; /** @type {?} */ var updateConnector = false; try { for (var _b = tslib_1.__values(Object.keys(changes)), _c = _b.next(); !_c.done; _c = _b.next()) { var propName = _c.value; /** @type {?} */ var change = changes[propName]; if (!change.firstChange && change.currentValue !== change.previousValue) { if (propName === 'mouseOverConnector') { updateConnector = true; } } } } catch (e_1_1) { e_1 = { error: e_1_1 }; } finally { try { if (_c && !_c.done && (_a = _b.return)) _a.call(_b); } finally { if (e_1) throw e_1.error; } } if (updateConnector && this.modelservice.isEditable()) { this.updateConnectorClass(); } }; /** * @private * @return {?} */ FcConnectorDirective.prototype.updateConnectorClass = /** * @private * @return {?} */ function () { /** @type {?} */ var element = $(this.elementRef.nativeElement); if (this.connector === this.mouseOverConnector) { element.addClass(FlowchartConstants.hoverClass); } else { element.removeClass(FlowchartConstants.hoverClass); } }; /** * @param {?} event * @return {?} */ FcConnectorDirective.prototype.dragover = /** * @param {?} event * @return {?} */ function (event) { // Skip - conflict with magnet /* if (this.modelservice.isEditable()) { return this.callbacks.edgeDragoverConnector(event, this.connector); }*/ }; /** * @param {?} event * @return {?} */ FcConnectorDirective.prototype.drop = /** * @param {?} event * @return {?} */ function (event) { if (this.modelservice.isEditable()) { return this.callbacks.edgeDrop(event, this.connector); } }; /** * @param {?} event * @return {?} */ FcConnectorDirective.prototype.dragend = /** * @param {?} event * @return {?} */ function (event) { if (this.modelservice.isEditable()) { this.callbacks.edgeDragend(event); } }; /** * @param {?} event * @return {?} */ FcConnectorDirective.prototype.dragstart = /** * @param {?} event * @return {?} */ function (event) { if (this.modelservice.isEditable()) { this.callbacks.edgeDragstart(event, this.connector); } }; /** * @param {?} event * @return {?} */ FcConnectorDirective.prototype.mouseenter = /** * @param {?} event * @return {?} */ function (event) { if (this.modelservice.isEditable()) { this.callbacks.connectorMouseEnter(event, this.connector); } }; /** * @param {?} event * @return {?} */ FcConnectorDirective.prototype.mouseleave = /** * @param {?} event * @return {?} */ function (event) { if (this.modelservice.isEditable()) { this.callbacks.connectorMouseLeave(event, this.connector); } }; FcConnectorDirective.decorators = [ { type: Directive, args: [{ // tslint:disable-next-line:directive-selector selector: '[fc-connector]' },] } ]; /** @nocollapse */ FcConnectorDirective.ctorParameters = function () { return [ { type: ElementRef } ]; }; FcConnectorDirective.propDecorators = { callbacks: [{ type: Input }], modelservice: [{ type: Input }], connector: [{ type: Input }], nodeRectInfo: [{ type: Input }], mouseOverConnector: [{ type: Input }], dragover: [{ type: HostListener, args: ['dragover', ['$event'],] }], drop: [{ type: HostListener, args: ['drop', ['$event'],] }], dragend: [{ type: HostListener, args: ['dragend', ['$event'],] }], dragstart: [{ type: HostListener, args: ['dragstart', ['$event'],] }], mouseenter: [{ type: HostListener, args: ['mouseenter', ['$event'],] }], mouseleave: [{ type: HostListener, args: ['mouseleave', ['$event'],] }] }; return FcConnectorDirective; }()); export { FcConnectorDirective }; if (false) { /** @type {?} */ FcConnectorDirective.prototype.callbacks; /** @type {?} */ FcConnectorDirective.prototype.modelservice; /** @type {?} */ FcConnectorDirective.prototype.connector; /** @type {?} */ FcConnectorDirective.prototype.nodeRectInfo; /** @type {?} */ FcConnectorDirective.prototype.mouseOverConnector; /** @type {?} */ FcConnectorDirective.prototype.elementRef; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"connector.directive.js","sourceRoot":"ng://ngx-flowchart/","sources":["lib/connector.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Directive, ElementRef, HostListener, Input, OnChanges, OnInit, SimpleChanges } from '@angular/core';\nimport { FcCallbacks, FcConnector, FcConnectorRectInfo, FcNodeRectInfo, FlowchartConstants } from './ngx-flowchart.models';\nimport { FcModelService } from './model.service';\n\n@Directive({\n  // tslint:disable-next-line:directive-selector\n  selector: '[fc-connector]'\n})\nexport class FcConnectorDirective implements OnInit, OnChanges {\n\n  @Input()\n  callbacks: FcCallbacks;\n\n  @Input()\n  modelservice: FcModelService;\n\n  @Input()\n  connector: FcConnector;\n\n  @Input()\n  nodeRectInfo: FcNodeRectInfo;\n\n  @Input()\n  mouseOverConnector: FcConnector;\n\n  constructor(public elementRef: ElementRef<HTMLElement>) {\n  }\n\n  ngOnInit(): void {\n    const element = $(this.elementRef.nativeElement);\n    element.addClass(FlowchartConstants.connectorClass);\n    if (this.modelservice.isEditable()) {\n      element.attr('draggable', 'true');\n      this.updateConnectorClass();\n    }\n    const connectorRectInfo: FcConnectorRectInfo = {\n      type: this.connector.type,\n      width: this.elementRef.nativeElement.offsetWidth,\n      height: this.elementRef.nativeElement.offsetHeight,\n      nodeRectInfo: this.nodeRectInfo\n    };\n    this.modelservice.connectors.setConnectorRectInfo(this.connector.id, connectorRectInfo);\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    let updateConnector = false;\n    for (const propName of Object.keys(changes)) {\n      const change = changes[propName];\n      if (!change.firstChange && change.currentValue !== change.previousValue) {\n        if (propName === 'mouseOverConnector') {\n          updateConnector = true;\n        }\n      }\n    }\n    if (updateConnector && this.modelservice.isEditable()) {\n      this.updateConnectorClass();\n    }\n  }\n\n  private updateConnectorClass() {\n    const element = $(this.elementRef.nativeElement);\n    if (this.connector === this.mouseOverConnector) {\n      element.addClass(FlowchartConstants.hoverClass);\n    } else {\n      element.removeClass(FlowchartConstants.hoverClass);\n    }\n  }\n\n  @HostListener('dragover', ['$event'])\n  dragover(event: DragEvent) {\n    // Skip - conflict with magnet\n    /* if (this.modelservice.isEditable()) {\n      return this.callbacks.edgeDragoverConnector(event, this.connector);\n    }*/\n  }\n\n  @HostListener('drop', ['$event'])\n  drop(event: DragEvent) {\n    if (this.modelservice.isEditable()) {\n      return this.callbacks.edgeDrop(event, this.connector);\n    }\n  }\n\n  @HostListener('dragend', ['$event'])\n  dragend(event: DragEvent) {\n    if (this.modelservice.isEditable()) {\n      this.callbacks.edgeDragend(event);\n    }\n  }\n\n  @HostListener('dragstart', ['$event'])\n  dragstart(event: DragEvent) {\n    if (this.modelservice.isEditable()) {\n      this.callbacks.edgeDragstart(event, this.connector);\n    }\n  }\n\n  @HostListener('mouseenter', ['$event'])\n  mouseenter(event: MouseEvent) {\n    if (this.modelservice.isEditable()) {\n      this.callbacks.connectorMouseEnter(event, this.connector);\n    }\n  }\n\n  @HostListener('mouseleave', ['$event'])\n  mouseleave(event: MouseEvent) {\n    if (this.modelservice.isEditable()) {\n      this.callbacks.connectorMouseLeave(event, this.connector);\n    }\n  }\n\n}\n"]}