UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

314 lines (313 loc) 35.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import * as tslib_1 from "tslib"; import { Directive, ElementRef, ViewContainerRef, Input, NgZone } from '@angular/core'; import { AbstractHasOptions } from '../share/AbstractHasOptions'; import { Option } from '../decorator/decorators'; const /** @type {?} */ DEFAULT_FORMAT = 'application/json'; const /** @type {?} */ DEFAULT_ALWAYS_FIRE_EVENT = false; const /** @type {?} */ DEFAULT_AUTO_ADD_CLASS = true; const /** @type {?} */ CLASS_NAME_DRAGGING = 'dragging'; export class Draggable extends AbstractHasOptions { /** * @param {?} elRef * @param {?} viewConRef * @param {?} ngZone */ constructor(elRef, viewConRef, ngZone) { super(); this.elementRef = elRef; if (this.elementRef !== null && typeof this.elementRef !== 'undefined') { // Auto add "draggable" html attr into dom $(this.elementRef.nativeElement).attr('draggable', 'true'); } // Resolve component instance try { this.component = (/** @type {?} */ (viewConRef))._data.componentView.component; } catch (/** @type {?} */ error) { } // Add drag event listeners ngZone.runOutsideAngular(() => { this.bindEvents(); }); } /** * @return {?} */ bindEvents() { if (this.elementRef !== null && typeof this.elementRef !== 'undefined') { $(this.elementRef.nativeElement).on('dragstart', (event) => { this.onDragStart.call(this, event.originalEvent); }); $(this.elementRef.nativeElement).on('dragend', (event) => { this.onDragEnd.call(this, event.originalEvent); }); $(this.elementRef.nativeElement).on('drag', (event) => { this.onDrag.call(this, event.originalEvent); }); } } /** * @return {?} */ ngOnInit() { if (this.format === null || typeof this.format !== 'string') { this.format = DEFAULT_FORMAT; } if (this.component === null || typeof this.component === 'undefined') { // Try to resolve "component" from @Input() options; if (this.options !== null && typeof this.options !== 'undefined') { // Test that it is a component instance if (typeof this.options.getDragStartDataTransfer === 'function') { this.component = this.options; } } } if (this.alwaysFireEvent === null || typeof this.alwaysFireEvent === 'undefined') { this.alwaysFireEvent = DEFAULT_ALWAYS_FIRE_EVENT; } if (this.autoAddClass === null || typeof this.autoAddClass === 'undefined') { this.autoAddClass = DEFAULT_AUTO_ADD_CLASS; } } /** * @param {?} event * @return {?} */ isDraggable(event) { if (this.component === null || typeof this.component === 'undefined') { return true; } if (typeof this.component.isDraggable !== 'function') { return true; } return this.component.isDraggable(event); } /** * @param {?} className * @return {?} */ addStyleClass(className) { if (this.elementRef !== null && typeof this.elementRef !== 'undefined') { $(this.elementRef.nativeElement).addClass(className); } if (this.component !== null && typeof this.component !== 'undefined' && this.component.elementRef !== null && typeof this.component.elementRef !== 'undefined') { $(this.component.elementRef.nativeElement).addClass(className); } } /** * @param {?} className * @return {?} */ removeStyleClass(className) { if (this.elementRef !== null && typeof this.elementRef !== 'undefined') { $(this.elementRef.nativeElement).removeClass(className); } if (this.component !== null && typeof this.component !== 'undefined' && this.component.elementRef !== null && typeof this.component.elementRef !== 'undefined') { $(this.component.elementRef.nativeElement).removeClass(className); } } /** * @param {?} event * @return {?} */ onDragStart(event) { if (this.component === null || typeof this.component === 'undefined') { return; } let /** @type {?} */ draggable = this.isDraggable(event); if (!draggable) { if (event !== null && typeof event !== 'undefined') { event.preventDefault(); } if (!this.alwaysFireEvent) { return; } } if (event !== null && typeof event !== 'undefined') { if (typeof this.component.getDragStartDataTransfer === 'function') { // Auto set data transfer properties if getDragStartDataTransfer() is available. let /** @type {?} */ dataTransfer = this.component.getDragStartDataTransfer(event); if (dataTransfer !== null && typeof dataTransfer !== 'undefined') { // We're not going to set "dropEffect" here since it should be // set in "dragover" event. // Set dataTransfer.effectAllowed if (typeof dataTransfer.effectAllowed === 'function') { // Auto resolve value from function's returned value if it is a function. event.dataTransfer.effectAllowed = dataTransfer.effectAllowed(event); } else if (typeof dataTransfer.effectAllowed !== 'undefined') { event.dataTransfer.effectAllowed = dataTransfer.effectAllowed; } // Set dataTransfer.files if (typeof dataTransfer.files === 'function') { // Auto resolve value from function's returned value if it is a function. event.dataTransfer.files = dataTransfer.files(event); } else if (typeof dataTransfer.files !== 'undefined') { event.dataTransfer.files = dataTransfer.files; } // Set dataTransfer.image if (typeof dataTransfer.image === 'function') { // Auto resolve value from function's returned value if it is a function. event.dataTransfer.setDragImage(dataTransfer.image(event), 0, 0); } else if (typeof dataTransfer.image !== 'undefined') { event.dataTransfer.setDragImage(dataTransfer.image, 0, 0); } let /** @type {?} */ format = this.format; if (typeof dataTransfer.format === 'function') { // Auto resolve value from function's returned value if it is a function. format = dataTransfer.format(event); } else if (typeof dataTransfer.format !== 'undefined') { format = dataTransfer.format; } if (format === null || typeof format === 'undefined') { format = DEFAULT_FORMAT; } let /** @type {?} */ data = null; if (typeof dataTransfer.data === 'function') { // Auto resolve value from function's returned value if it is a function. data = dataTransfer.data(event); } else if (typeof dataTransfer.data !== 'undefined') { data = dataTransfer.data; } if (format.toLowerCase() === 'application/json') { // Auto serialize data into json if it is not json string. try { JSON.parse(data); } catch (/** @type {?} */ e) { // The given "data" is not json string try { data = JSON.stringify(data); } catch (/** @type {?} */ e) { // The data cannot be parsed to json string data = null; } } } if ((format !== null && typeof format !== 'undefined') || (data !== null && typeof data !== 'undefined')) { event.dataTransfer.setData(format, data); } } } } if (this.autoAddClass) { this.addStyleClass(CLASS_NAME_DRAGGING); } if (typeof this.component.onDragStart === 'function') { this.component.onDragStart(event); } } /** * @param {?} event * @return {?} */ onDragEnd(event) { if (this.component === null || typeof this.component === 'undefined') { return; } if (this.autoAddClass) { this.removeStyleClass(CLASS_NAME_DRAGGING); } if (typeof this.component.onDragEnd === 'function') { if (this.alwaysFireEvent || this.isDraggable(event)) { this.component.onDragEnd(event); } } } /** * @param {?} event * @return {?} */ onDrag(event) { if (this.component === null || typeof this.component === 'undefined') { return; } if (typeof this.component.onDrag === 'function') { if (this.alwaysFireEvent || this.isDraggable(event)) { this.component.onDrag(event); } } } } Draggable.DEFAULT_FORMAT = DEFAULT_FORMAT; Draggable.CLASS_NAME_DRAGGING = CLASS_NAME_DRAGGING; Draggable.DEFAULT_ALWAYS_FIRE_EVENT = DEFAULT_ALWAYS_FIRE_EVENT; Draggable.DEFAULT_AUTO_ADD_CLASS = DEFAULT_AUTO_ADD_CLASS; Draggable.decorators = [ { type: Directive, args: [{ selector: '[phxDraggable]' },] }, ]; /** @nocollapse */ Draggable.ctorParameters = () => [ { type: ElementRef, }, { type: ViewContainerRef, }, { type: NgZone, }, ]; Draggable.propDecorators = { "options": [{ type: Input, args: ['phxDraggable',] },], "format": [{ type: Input, args: ['dragFormat',] },], "component": [{ type: Input, args: ['dragTarget',] },], "alwaysFireEvent": [{ type: Input, args: ['dragFireEvent',] },], "autoAddClass": [{ type: Input, args: ['dragAddClass',] },], }; tslib_1.__decorate([ Option('format'), tslib_1.__metadata("design:type", String) ], Draggable.prototype, "format", void 0); tslib_1.__decorate([ Option('target'), tslib_1.__metadata("design:type", Object) ], Draggable.prototype, "component", void 0); tslib_1.__decorate([ Option('fireEvent'), tslib_1.__metadata("design:type", Boolean) ], Draggable.prototype, "alwaysFireEvent", void 0); tslib_1.__decorate([ Option('addClass'), tslib_1.__metadata("design:type", Boolean) ], Draggable.prototype, "autoAddClass", void 0); function Draggable_tsickle_Closure_declarations() { /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ Draggable.decorators; /** * @nocollapse * @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} */ Draggable.ctorParameters; /** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */ Draggable.propDecorators; /** @type {?} */ Draggable.DEFAULT_FORMAT; /** @type {?} */ Draggable.CLASS_NAME_DRAGGING; /** @type {?} */ Draggable.DEFAULT_ALWAYS_FIRE_EVENT; /** @type {?} */ Draggable.DEFAULT_AUTO_ADD_CLASS; /** @type {?} */ Draggable.prototype.options; /** @type {?} */ Draggable.prototype.format; /** @type {?} */ Draggable.prototype.component; /** @type {?} */ Draggable.prototype.alwaysFireEvent; /** @type {?} */ Draggable.prototype.autoAddClass; /** @type {?} */ Draggable.prototype.elementRef; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Draggable.directive.js","sourceRoot":"ng://com.phloxui/","sources":["lib/directive/Draggable.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Directive, ElementRef, ViewContainerRef, Input, HostListener, NgZone } from '@angular/core';\n\nimport { AbstractHasOptions } from '../share/AbstractHasOptions';\n\nimport { Option } from '../decorator/decorators';\n\nimport { DragDataTransfer } from '../component/model/models';\n\nconst DEFAULT_FORMAT: string = 'application/json';\nconst DEFAULT_ALWAYS_FIRE_EVENT: boolean = false;\nconst DEFAULT_AUTO_ADD_CLASS: boolean = true;\nconst CLASS_NAME_DRAGGING: string = 'dragging';\n\ndeclare var $: any;\n\n@Directive({\n  selector: '[phxDraggable]'\n})\nexport class Draggable extends AbstractHasOptions implements OnInit {\n\n  public static readonly DEFAULT_FORMAT: string = DEFAULT_FORMAT;\n  public static readonly CLASS_NAME_DRAGGING: string = CLASS_NAME_DRAGGING;\n  public static readonly DEFAULT_ALWAYS_FIRE_EVENT: boolean = DEFAULT_ALWAYS_FIRE_EVENT;\n  public static readonly DEFAULT_AUTO_ADD_CLASS: boolean = DEFAULT_AUTO_ADD_CLASS;\n\n  @Input('phxDraggable')\n  protected options: any;\n\n  @Input('dragFormat')\n  @Option('format')\n  private format: string;\n\n  @Input('dragTarget')\n  @Option('target')\n  private component: any;\n\n  @Input('dragFireEvent')\n  @Option('fireEvent')\n  private alwaysFireEvent: boolean;\n\n  @Input('dragAddClass')\n  @Option('addClass')\n  private autoAddClass: boolean;\n\n  private elementRef: ElementRef;\n\n  constructor(elRef: ElementRef, viewConRef: ViewContainerRef, ngZone: NgZone) {\n    super();\n\n    this.elementRef = elRef;\n    if (this.elementRef !== null && typeof this.elementRef !== 'undefined') {\n      // Auto add \"draggable\" html attr into dom\n      $(this.elementRef.nativeElement).attr('draggable', 'true');\n    }\n\n    // Resolve component instance\n    try {\n      this.component = (<any>viewConRef)._data.componentView.component;\n    } catch (error) {\n    }\n\n    // Add drag event listeners\n    ngZone.runOutsideAngular(() => {\n      this.bindEvents();\n    });\n  }\n\n  private bindEvents(): void {\n    if (this.elementRef !== null && typeof this.elementRef !== 'undefined') {\n      $(this.elementRef.nativeElement).on('dragstart', (event: any) => {\n        this.onDragStart.call(this, event.originalEvent);\n      });\n      $(this.elementRef.nativeElement).on('dragend', (event: any) => {\n        this.onDragEnd.call(this, event.originalEvent);\n      });\n      $(this.elementRef.nativeElement).on('drag', (event: any) => {\n        this.onDrag.call(this, event.originalEvent);\n      });\n    }\n  }\n\n  public ngOnInit(): void {\n    if (this.format === null || typeof this.format !== 'string') {\n      this.format = DEFAULT_FORMAT;\n    }\n    if (this.component === null || typeof this.component === 'undefined') {\n      // Try to resolve \"component\" from @Input() options;\n      if (this.options !== null && typeof this.options !== 'undefined') {\n        // Test that it is a component instance\n        if (typeof this.options.getDragStartDataTransfer === 'function') {\n          this.component = this.options;\n        }\n      }\n    }\n    if (this.alwaysFireEvent === null || typeof this.alwaysFireEvent === 'undefined') {\n      this.alwaysFireEvent = DEFAULT_ALWAYS_FIRE_EVENT;\n    }\n    if (this.autoAddClass === null || typeof this.autoAddClass === 'undefined') {\n      this.autoAddClass = DEFAULT_AUTO_ADD_CLASS;\n    }\n  }\n\n  private isDraggable(event: any): boolean {\n    if (this.component === null || typeof this.component === 'undefined') {\n      return true;\n    }\n    if (typeof this.component.isDraggable !== 'function') {\n      return true;\n    }\n\n    return this.component.isDraggable(event);\n  }\n\n  private addStyleClass(className: string) {\n    if (this.elementRef !== null && typeof this.elementRef !== 'undefined') {\n      $(this.elementRef.nativeElement).addClass(className);\n    }\n    if (this.component !== null && typeof this.component !== 'undefined' &&\n        this.component.elementRef !== null && typeof this.component.elementRef !== 'undefined') {\n      $(this.component.elementRef.nativeElement).addClass(className);\n    }\n  }\n\n  private removeStyleClass(className: string) {\n    if (this.elementRef !== null && typeof this.elementRef !== 'undefined') {\n      $(this.elementRef.nativeElement).removeClass(className);\n    }\n    if (this.component !== null && typeof this.component !== 'undefined' &&\n        this.component.elementRef !== null && typeof this.component.elementRef !== 'undefined') {\n      $(this.component.elementRef.nativeElement).removeClass(className);\n    }\n  }\n\n  // @HostListener('dragstart', ['$event'])\n  private onDragStart(event: any): void {\n    if (this.component === null || typeof this.component === 'undefined') {\n      return;\n    }\n\n    let draggable: boolean = this.isDraggable(event);\n    if (!draggable) {\n      if (event !== null && typeof event !== 'undefined') {\n        event.preventDefault();\n      }\n\n      if (!this.alwaysFireEvent) {\n        return;\n      }\n    }\n\n    if (event !== null && typeof event !== 'undefined') {\n      if (typeof this.component.getDragStartDataTransfer === 'function') {\n        // Auto set data transfer properties if getDragStartDataTransfer() is available.\n        let dataTransfer: DragDataTransfer = this.component.getDragStartDataTransfer(event);\n\n        if (dataTransfer !== null && typeof dataTransfer !== 'undefined') {\n          // We're not going to set \"dropEffect\" here since it should be\n          // set in \"dragover\" event.\n\n          // Set dataTransfer.effectAllowed\n          if (typeof dataTransfer.effectAllowed === 'function') {\n            // Auto resolve value from function's returned value if it is a function.\n            event.dataTransfer.effectAllowed = dataTransfer.effectAllowed(event);\n          } else if (typeof dataTransfer.effectAllowed !== 'undefined') {\n            event.dataTransfer.effectAllowed = dataTransfer.effectAllowed;\n          }\n\n          // Set dataTransfer.files\n          if (typeof dataTransfer.files === 'function') {\n            // Auto resolve value from function's returned value if it is a function.\n            event.dataTransfer.files = dataTransfer.files(event);\n          } else if (typeof dataTransfer.files !== 'undefined') {\n            event.dataTransfer.files = dataTransfer.files;\n          }\n\n          // Set dataTransfer.image\n          if (typeof dataTransfer.image === 'function') {\n            // Auto resolve value from function's returned value if it is a function.\n            event.dataTransfer.setDragImage(dataTransfer.image(event), 0, 0);\n          } else if (typeof dataTransfer.image !== 'undefined') {\n            event.dataTransfer.setDragImage(dataTransfer.image, 0, 0);\n          }\n\n          let format: string = this.format;\n          if (typeof dataTransfer.format === 'function') {\n            // Auto resolve value from function's returned value if it is a function.\n            format = dataTransfer.format(event);\n          } else if (typeof dataTransfer.format !== 'undefined') {\n            format = dataTransfer.format;\n          }\n          if (format === null || typeof format === 'undefined') {\n            format = DEFAULT_FORMAT;\n          }\n\n          let data: any = null;\n          if (typeof dataTransfer.data === 'function') {\n            // Auto resolve value from function's returned value if it is a function.\n            data = dataTransfer.data(event);\n          } else if (typeof dataTransfer.data !== 'undefined') {\n            data = dataTransfer.data;\n          }\n          if (format.toLowerCase() === 'application/json') {\n            // Auto serialize data into json if it is not json string.\n            try {\n              JSON.parse(data);\n            } catch(e) {\n              // The given \"data\" is not json string\n              try {\n                data = JSON.stringify(data);\n              } catch(e) {\n                // The data cannot be parsed to json string\n                data = null;\n              }\n            }\n          }\n\n          if ((format !== null && typeof format !== 'undefined') ||\n              (data !== null && typeof data !== 'undefined')) {\n            event.dataTransfer.setData(format, data);\n          }\n        }\n      }\n    }\n\n    if (this.autoAddClass) {\n      this.addStyleClass(CLASS_NAME_DRAGGING);\n    }\n\n    if (typeof this.component.onDragStart === 'function') {\n      this.component.onDragStart(event);\n    }\n  }\n\n  // @HostListener('dragend', ['$event'])\n  private onDragEnd(event: any): void {\n    if (this.component === null || typeof this.component === 'undefined') {\n      return;\n    }\n\n    if (this.autoAddClass) {\n      this.removeStyleClass(CLASS_NAME_DRAGGING);\n    }\n\n    if (typeof this.component.onDragEnd === 'function') {\n      if (this.alwaysFireEvent || this.isDraggable(event)) {\n        this.component.onDragEnd(event);\n      }\n    }\n  }\n\n  // @HostListener('drag', ['$event'])\n  private onDrag(event: any): void {\n    if (this.component === null || typeof this.component === 'undefined') {\n      return;\n    }\n\n    if (typeof this.component.onDrag === 'function') {\n      if (this.alwaysFireEvent || this.isDraggable(event)) {\n        this.component.onDrag(event);\n      }\n    }\n  }\n}\n"]}