com.phloxui
Version:
PhloxUI Ng2+ Framework
344 lines (343 loc) • 36.8 kB
JavaScript
/**
* @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';
var /** @type {?} */ DEFAULT_FORMAT = 'application/json';
var /** @type {?} */ DEFAULT_ALWAYS_FIRE_EVENT = false;
var /** @type {?} */ DEFAULT_AUTO_ADD_CLASS = true;
var /** @type {?} */ CLASS_NAME_DRAGGING = 'dragging';
var Draggable = /** @class */ (function (_super) {
tslib_1.__extends(Draggable, _super);
function Draggable(elRef, viewConRef, ngZone) {
var _this = _super.call(this) || this;
_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(function () {
_this.bindEvents();
});
return _this;
}
/**
* @return {?}
*/
Draggable.prototype.bindEvents = /**
* @return {?}
*/
function () {
var _this = this;
if (this.elementRef !== null && typeof this.elementRef !== 'undefined') {
$(this.elementRef.nativeElement).on('dragstart', function (event) {
_this.onDragStart.call(_this, event.originalEvent);
});
$(this.elementRef.nativeElement).on('dragend', function (event) {
_this.onDragEnd.call(_this, event.originalEvent);
});
$(this.elementRef.nativeElement).on('drag', function (event) {
_this.onDrag.call(_this, event.originalEvent);
});
}
};
/**
* @return {?}
*/
Draggable.prototype.ngOnInit = /**
* @return {?}
*/
function () {
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 {?}
*/
Draggable.prototype.isDraggable = /**
* @param {?} event
* @return {?}
*/
function (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 {?}
*/
Draggable.prototype.addStyleClass = /**
* @param {?} className
* @return {?}
*/
function (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 {?}
*/
Draggable.prototype.removeStyleClass = /**
* @param {?} className
* @return {?}
*/
function (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 {?}
*/
Draggable.prototype.onDragStart = /**
* @param {?} event
* @return {?}
*/
function (event) {
if (this.component === null || typeof this.component === 'undefined') {
return;
}
var /** @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.
var /** @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);
}
var /** @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;
}
var /** @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 {?}
*/
Draggable.prototype.onDragEnd = /**
* @param {?} event
* @return {?}
*/
function (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 {?}
*/
Draggable.prototype.onDrag = /**
* @param {?} event
* @return {?}
*/
function (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 = function () { return [
{ 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);
return Draggable;
}(AbstractHasOptions));
export { Draggable };
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"]}